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بسم الله الرحمن الرحيم 


بعون الله و توفيقه سأبدأ سلسلة من الحاضرات لتعليم أوراكل ديفلوبر » بجحيث يصبح 
الإخوة المتابعون هذه السلسلة بعد إتمامها إن شاء الله » مؤهلين لخلق نظام مكتمل 
باستخدام جميع الأدوات المختلفة في أوراكل ديفلوبر»واستيفاء هذا الهدف فقد ةم 
اختيار نظام جامعة مبسط للتطبيق عليه.. 


مع العلم أن هذا الكتاب هو في الأصل محاضرات درستها في الجامعة وقمت بتطبيقها 
وترتيبها وجمعها في هذا الكتيب وجيع الحقوق محفوظة للأستاذ وديع القباطي . 
جمع وترتيب أخوكم في الله... 
م/ عبدالله اليحوي 
لأي استفسار هذا ايلي 


a_alyahawiQ@hotmail.com 


و لا أريد منكم سوى الدعاء لي في صلواتكم و سأكون سعيدا جدا بذلك 


jlyahawiOnotmail e0 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


Developer 6i رة‎ las رس‎ 


المحاضرة ا .وض وع الصفحة 

E O a )501 , ۲1/501( مقدمة عن‎ # 

1 المستخدمون والصلاحيات وعلاقتهما بالد(عاه) O‏ 
# اتاو خم جيذ ومفهة لاحات O | eR‏ 

إنشاء الجداول والقيود التابعة لها N‏ 

N RR RR RSS Form Builder Jai % 

EL ys (From Builder)dفd الشاشات الرئیسية‎ 
E Object Navigator ٽlيوتحم نبذة مُبسطة عن‎ 

a ooo Developer 6i الحفظ والتنفيذ في برامج‎ 

N r ooo M0DULE من خصائص‎ 

e ee See oe ٣ع الأحداث كمع‎ 

E SL (Message & Alert) JÛilwرll‎ % 3 
E E Data Blocks ختل البيانات‎ 
es e visual Attribute ج الخصائص المرئية‎ 

E Seal lItems(Input & Non_lInput) رصliall‎ 4% 

التحكم بالخصائص بڊرaجÎ (Window & Block & Item)‏ د 

* | المتحولات العامة والمتحولات المحلية a E oo‏ 
# التحكم بالخصائص برمجيا عن طريق المتحولات العامة ا 
العلاقات EO a Relations‏ 

20 

22 

23 


4 | 
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حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


E a aaa List Item(Static & Dynamic) رصie‎ % 7 
2 LOVs(Static & Dynamic _ Manually & Wizrad) م القائمة المركبة‎ 
E ea Radio Group(Radio Buttons) دıرفll عصر الإختيار‎ + 

N Check Box عنصر الإختيار المتعدد‎ + 8 
a ٣ج"۷جومو أنواع القماشية‎ 4 
(Content & Stacked & Tab & Vertical _ Horizontal Toolbar) 
37 : ا‎ 
DD O TT Report Builder Jii 4% 
40 . 5 ٤ " * * 9 
E (Report Builder) ج الشاشات الرئيسية‎ 

40 . . » 0» ج‎ 3 OT 4 9 
EO Object Navigator ٽlيوتحھمn نبذة مبسطة عن‎ 
4 Data Model(System Parameters & User Parameters) ٽIنlaبll‎ جذومi‎ % 
| Layout Editor(Header & Body & Footer) ãسنill‎ جذومi‎ 4% 
E Groups ۾ المجامیيع‎ 

و أ * الإضافة بإستخدام (حقل صيغة aاں o O O )۴٠٣ ٣‏ 
الإضافة باستخذام (الإسكعام 6ة 01 E‏ 
48 
+ حقول التجميع ۷ا2" ay Su"‏ 
% llلتوÛlgم a O oooy Menu‏ 

القوائم المنبثقة بزر الفأرة الأيمن a Popup Menu‏ 
#٭ طرق الربط بین أکثر من )۴٥۲٣۶(‏ أو بين ال()Form( (Report)dls‏ د 
4% ganllعnlږںٽ ei ek Parameters‏ 
“ê +‏ 2 55 
التعل مم ماغات اتصوررة a‏ 

| اکل م تت ات ao‏ 
الإستيراد والتصدير E‏ 

ملحق الصيغ العامة لجمل اه5 CT‏ 
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حاضرات فی اوراکل دفلویر أ6 ORACLE‏ 


تعتبر ال(ا۲|1/5Q‏ , SQ1؟)‏ هي البنية الأساسية لبرنامج Developer 6i‏ « 
التي تمتلك أنواع من التعليمات : 


: DM1 لغة معالحة البيانات‎ ٠ 
والتي تتعامل مع محتويات الجداول لذلك يمكن التراجع عنها بعد تنفيذ تعليماتها لأنها لا تتعامل مع‎ 
الول هة‎ 


وتحوي التعليمات ( اءعاعء لإستعراض البيانات - |٣56۲‏ لإدخالها - عtمdمu‏ لتعديلها - مetماeمd‏ لحذفها) › 


: 001 لغة تعريف إلبيانات‎ ٠ 
› والتي تتعامل مع بنية ال(5#ةطةاة0) لذلك لا يمكن التراجع بعد تنفيذ تعليماتها‎ 


وتحوي التعليمات »٠٠۵(‏ لإنشاء الكائن - ۲اا لتعديل مواصفات الكائن - ۲٠٧‏ لحذف الكائن نهائيا) › 


: 0٣1ا لغة التحكم بالبيانات‎ ٠ 
. لمنح الصلاحية - هء)ه۷٠۲ لسحب الصلاحية)‎ 9۲2١( وتحوي التعليمات‎ 


وعدد من الدواJ‏ lلتقيlسي Functions‏ : 


: الدوال الحسابية‎ ٠ 
Sum( ) = Max( ) - Min( ) - Avg ( ) - Count( ) = 


Abs( ) - Mod( ) - Sqrt( ) - Power( ) - Floor( ) = Ceil( ) = Round( ) = 
Nv1( , ) 


: الدوال المحرفية‎ ٠ه‎ 
Lower( ) ~- Upper( ) = Initcap( ) - Concat( , ) = Substar( , , ) ~— 
Length( ) - Instr( , ) - Lpad( , , ) ¬ Rpad( , , ) = Ltrim( ) - Rtrim( 
) 


: دوال التاريخ والوقت‎ ٠ 
Sysdate - Months _ Between( , ) > Add Months( ) > Next Day( , ) 
Last_Day( ) 


ا وعدد من عوامل التشة 


r, ll , .., 


In , Not In , Is Null , Is Not Null , Between X And ¥ , Not Between X 
And ¥ , X Like ¥ , X Not Like ¥ 
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على إفتراض آن أربعة محاسبين يعملون في مجالهم بشبكة عمل موحدة فإنه من الأفضل 2م | 
جميعاً إسم 56۲لا وحيد وكلمة المرور التابعة له وذلك بغرض معرفة الأخطاء ممن إرتكبت ومن هو المسئول 
المباشر عنها لذلك نحدد لكل شخص إسم #۲ءلا وكلمة مرور خاصة به وأمنحه كذلك الصلاحيات ذاتها › 
لذلك نجد أن تجميع صلاحيات المسة ET‏ داخل (۵ا۸80) واحدة نقوم بإنشائها يوفر علينا الكثير من الجهد 


فعلی افتراض أنه یوجد لدینا 20 جدول وأردنا منح کل جدول 


(صلاحية الإستعراض اءعاعء - صلاحية الإدخال أا١عء"|‏ - صلاحية التعديل ةلمن - صلاحية الحذف 
عtعاعd)يعني‏ أننا سنحتاج إلى منح 4 صلاحيات * 20 حدول = 80 صلاحية للمستخدم الواحد » أي 320 
صلاحبة للمستخدمين الأربعة nnnk‏ 


ولكن إذا قمنا بتجميع هذه ال(80 الصلاحية) على الجداول داخل (6ا۸0) واحدة فإننا سنحتاج فقط إلى منح 
4 صلاحية بواقع 80 صلاحية إلى داخل (6ا۸0) ومن ثم 4 صلاحيات للمستخدمين (منح صلاحية ال( عا۸0) 
لكل مستخدم) . والتفاصيل نفسها تنطبق عند عملية سحب الصلاحيات . 


ا5۵ / P1‏ : وشكل البرنامج فيها كالتالي: 
Declare‏ 


وفي هذا الجزء يتم الإعلان عن المتحولات والمؤشرات ١١١۲ل‏ و الثوابت ونلاحظ هنا عند استخدامنا 
للمؤشرات أن جملة »اه5 هذه لا تحتوي على معامل الإسناد |٠0‏ لأن طبيعة عمل المؤشرات يعتمد على 
إحضار جميع السجلات دفعة واحدة (بدون تزامن) ومن ثم معالجتها على سجل سجل . 


Begin 


وفي هذا الجزء يتم كتابة البرنامج بأوامر ال(ا@۴1/5Q‏ ,ا5Q)‏ ونلاحظ هنا أن جملة ٤6ا56‏ هذه تحتو ي على 
معامل الإسناد ¡٣0‏ ويشترط فيها كتابة شروط الربط بين الجداول ۷٣۴۲٠١‏ لإرجاع سجل وحيد . 


Exception 


وفي هذا الجزء تتم معالجة الأخطاء المتوقع حدوثها أثناء تنفيذ البرنامج وهي تلك الأخطاء التي لا تكتشف 
أثناء الترحمة #اأم "0 ( ليست أخطاء صيغة 5۷١3×‏ ) ومن هذه الأخطاء (الاستثناءات) : 


› وتستخدم عندما لا يعي الإستعلام أي بيانات حسب الشرط‎ : n0_data_found 
›» وتستخدم عندما يعيد الإستعلام أكثر من سجل حسب الشرط‎ : t00_maN¥۷_r0NS 
› وتستخدم عندما تتم القسمة على صفر‎ : zeا0_devidedإ‎ 

› وتستخدم عندما یکون المؤشر مفتوحاً مرة أخرى دون إغلاقه‎ : cursor_already_open 

. وتستخدم من أجل ألا يتم إيقاف البرنامج لأي خطأً كان (من المفترض كتابتها دائماً)‎ : othe ٠ 


2 


إنشاء إنلشاءمستخلدم جلديلك جديد : 
[SYSTEM/MANAGER‏ :سيم المستخدم 


mM Start > Programs 2 Oracle - oracle > 


TT 
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ولعمل ذلك نقوم آولاً بالدخول إلى برنامج كuا۴‏ 801 حسب الخطوات السابقة لنلاحظ ظهور شاشة تطالب 


بادخال إسم للمستخدم وكلمة المرور الخاصة به . (حالياً نكتب إسم المستخدم 5۲5۲M‏ وكلمة 
lلمرور (MANAGER‏ 


S۷5٤١ نقوم بكتابة هذا الأمر أمام محث ا50 للتأكد من المستخدم الحالي هو مدير النظام‎ ٠ 
SQL> show user ; 


user is "SYSTEM" 


1۸1Z نقوم بانشاء مستخدم جديد اسمه 5۲ل وكلمة السر‎ ۰ 
SQL> create user ust identified by taiz ; 


User created. 


UST للمستخدم‎ )Roاe‎ ]connect , resource])J| ini 


SQL> grant connect , resource to ust ; 
Grant succeeded. 


UST للمستخدم‎ )Roاe‎ ]exp_Êfull_database , imp_full_database])Jl zini 
SQL> grant exp_full database , imp_full database to ust ; 


Grant succeeded. 


ال5١ نقوم الآن بالاتصال بالمستخدم‎ ٠ 
SQL> connect ust ; 


Enter password : x**** 
Connected. 


٠‏ نتأكد من أننا داخل المستخدم 51ل فعلياً 
SQL> show user ;‏ 


user is "UST" 


LT 
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ه٠‏ نقوم بإنشاء الجداول التالية للمستخدم 51ل (بحسب المواصفات والقيود المذكورة لكل حقل) 


Table : 
faîmë Fields Name 
Sec_No Sec_Name 
Section number (2) varchar2 (50) 
(P. K) (Not Null) 
LvI_No LvI_Name 
Lvl number (1) varchar2 (50) 
(P. K) (Not Null) 
Stu_No Stu_Name Stu_Sec Stu_Lvl 
number (3) varchar2 (50) number (2) number (1) 
P. K Not Null F.K F.K 
su PEM | (Nou) OE (EK) 
Stu_Add Stu_BrthDt Stu_Avg Stu_CertType 
varchar2 (50) date number (5,2) number(1) 
Sub_No Sub_Name Sub_Sec Sub_Lvl 
Subject number (3) varchar2(50) number(2) number(1) 
(P. K) (Not Null) (F.K) (F.K) 
Mark_Sec Mark_Lvl Mark_Stu Mark_Sub 
number (2) number (1) number (3) number (3) 
F.K F.K 2 
(FW | (ER (EK) (F.K) 
Mark_Yj Mark_Ht Mark_Ft 
number (5, 2) number (5, 2) number (5,2) 
(Check 0 .. 20) (Check 0 .. 20) (Check 0 .. 60) 


SQL> create table Section (Sec _ No number (2) primary key , 


Sec_ Name varchar2 (50) not null) ; 


Table created. 


SQL> create table Lvl (Lvl No number (1) primary key , 


Lvl Name varchar2 (50) not null) ; 


LT 


Table created. 
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r 


r 


r 


primary key , 


Section (Sec_ no) 


Lvl (LvLI no) , 


Subject (Sub_No number (2) primary key , 


subsec references Section (Sec_No) , 
sublvl references Lvl (Lvl _ No) , 


substu references stu (Stu_No) ) ; 


Section (Sec _ No) 
Lvl (Lvl _ No) , 
stu (Stu _No) , 


subject (Sub_No) 


stusecfk references 
stulvlfk references 


varchar2 (50) , Stu _ BrthDt date , 


number (1)) ; 


ksec references 


klvl references 


kstu references 


ksub references 


r 


Stu_ Name varchar2 (50) not null 


onstraint 


onstraint 


, Stu _ CertTyp 


r 


ma 


ma 


ma 


ma 


chkY¥]j check (Mark Yj between 0 and 20) 


chkHt check (Mark Ht between O0 and 20) 


chkFt check (Mark Ft between O0 and 60)) 


NOE BULL 


onstraint 


onstraint 


onstraint 


ORACLE 


number (2) c 


number (1) c 


number (5,2) 


Stu_ Sec 
Stu_Lvl 
Stu_ Add 


Stu_Avg 


SQL> create table Stu (Stu _No number (3) 


Table created. 


Sub_ Sec number (2) c 
Sub_Lvl number (1) c 


Sub_ Stu number (3) c 


tabl 


Sub_ Name varchar2 (50) 


SQL> creat 


Table created. 


SQL> create table Mark ( 


constraint 


constraint 


constraint 


constraint 


constrain 


constrain 


constrain 


umber (2) 


umber (1) 


umber (3) 


umber (2) 


k Sec n 
k Lvl n 
k Stu n 


k_ Sub n 


k Yj number (5,2) 


k_ Ht number (5,2) 


k_ Ft number (5,2) 


mm 1 
Table creakgd. NawiChotmail( 
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ملاحظات هامة : 


2. عند إنشاء أي مستخدم جديد فإن ذلك يكون من داخل المستخدم 5۲5۲۴١۷‏ وذلك لأنه قادر على 
الإنشاء من خلال صلاحية ال([08۸] عاه۸) التي يمتلكها . 

. لنتمكن من إتمام عملية الإتصال بالمستخدم ١5ا‏ بنجاح يجب منحه صلاحية إنشاء الجلسة 
Create Session‏ من خلال ال([†اconnec]‏ eاRo)‏ لأن هذه الصلاحية مضمنة فيها . 

.٤‏ عند إنشاء الجداول فإننا نقوم بالإتصال بالمستخدم 51ل وذلك من أجل أن تكون الجداول المنشئة 
تابعة له . 


LLI 


حاضرات فی اوراکل دىفلویر أ6 


ORACLE 


اخهافرة اأشاسة 


Developer 6i %‏ : 
هو الواجهة التي تمكننا من عمل برامج يتخاطب بها 
ال( ٣هكلا)‏ مع قاعدة البيانات وهو يحتوي العديد من 


البرامج (الأدوات) المساعدة في أوراكل مثل : 


Graphics Builder - Report Builder - Form Builder 
إلخ.‎ ... 


9 


:_Form Builder 
)لكع١ أداة تستخدم لبناء النماذج التي يستخدمها ال(‎ 
. بکل عناصرها‎ 


: Form Builder Jii % 


Form Builder 
| 2 
ھ‎ 1 


# Start > Programs > Oracle Forms 6i-orantf > Form Builder 


فتظهر أولاً شاشة ترحيبية يمكن من خلالها تحديد ما إذا 


٤ 


اریع خبارات وهي : 


« Data Block تٽlنilıبll إستخدام معالج كتلة‎ ٠ 
٤ بناء نموذج جديد يدوياً‎ 6 

ه فتح نموذج موجود مسبقاً » لک 
۰ بناء نموذج يعتمد على قالب . 


› عرض الجولة السريعة (مفاهيم)‎ ٠ 


كان المطلوب البدء بالتصميم أو بالتعليم » فالتصمىم 


wi elcome to the Form Builder 


Where to start 
Designing:  @ lse the Data Block Wizard 


Buk a new form manually‏ »چ 
(f Open an gxisting form‏ 


f Bud a form based on a template تکشاف کروت ال میحات (مهام)‎ | ۴ 
Learning: f Run the Quick Tour (concepts) (حالياً نختار البدء بالتصميم‎ 
Oracle Developer f Explore the Cue Cards (tasks) Data ا اھ مال تلة السانات‎ 


)0۸ تم نضغط‎ Block) 


لتظهر بعد ذلك شاشة ترحيبية خاصة بمعالج 
كتلة البيانات )0ا8 2ا03 (فنضغط التالي) 


WV Display at startup 


| سس لس لع 


[jalan 
10 ل‎ 
ڪ‎ 
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. إجراء مخزن.‎ ٠ 
(حاليآ سنختار حدول آو مشهد تم‎ 
Data Block Wizard × نصعط التالي)‎ 
ek: بعد ذلك يطلب إسم الجدول أو المشهد‎ 
aera Data الذي ستؤخذ منه كتلة البيانات‎ 
i « Block 
@ Tae ولعمل ذلك لابد من الإرتباط أولاً بقاعدة‎ 
البيانات وذلك بالضغط على الزر‎ 
E Browse... 
a ڪڪ‎ (Password )Jlg (User )J| وكتابة إسم‎ 


بشكل صحيح ومن تم الضغط على الزر 


connect 
: فتحديد طريقة العرض‎ 
Data Block Wizard × 
Enter a table or view on which to base yout data block. هل ستگون لما يتعلق‎ 
Ten re a oRrnê DE POU SPEC E BIRE بالمستخدم الحالي (الذي تم‎ 
الإرتباط من خلاله) أم‎ 
Betesh | I Enforce data irkegrily لمستخدمين آخرین أم لكليهما ء‎ 
Available Colurens Dalabase Items وتحدید ما نريد تضمينه من‎ . 
E › الجداول والمشاهد والمرادفات‎ 
E2 فإختيار الجدول أو المشهد أو‎ ٠ 


cml‏ ا 
ل 


User Name: [usTraz 
EES EE] س‎ 


Password: 
. المرادف المطلوب‎ Database: | ا‎ 
(حاليا سنختار إسم المستخدم ١5ل وكلمة السر1۸12ء‎ co | __ e | 


ومن حداول هذا المستخدم الحالي نختار الجدول 5۲۷) 


وبالتالي تظهر الحقول في ال (أاكأا) فنختار منها الحقول 
المطلوب التعامل معها بواسطة الأزرار < . << . > . >> (حالياً سنختار << ثم نضغط التالي) 


E7 
EE CBSE ERDE 
Then select the cokımns that shouid appease a3 hems. 
Tobie or view 
ن‎ 
Reftesh | r” Enforce dala iriegrly 
Avalable Cokımns Datsbese terns 


2 E 


Enla DE ER OED Pot E a ES 
Then select the columns that should appear 
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e 


ا ج ی 


تظهر شاشة التهاني والتبريكات a0٥٣5‏ اra†uوcon‏ لتعلن 
عن إتمام معالح كتلة البيانات )٤0ا8‏ هة بنجاح » وقبل أن 


نضغط ۶۸ا٣۴‏ نرى وجود الخبارين التاليين : 


ه٠‏ إنشاء كتلة البيانات ععها8 ها0 بعد الإتصال 
بمعالج التصميم (المخطط أا۷0ةا) > 
ه٠‏ إنشاء كتلة البيانات فقط . 
(حالياً سنختار إنشاء كتلة البيانات بعد الإتصال 


بمعالج التصميم utام‏ رها تم نضغط نهاية) 


لتظهر بعد ذلك شاشة ترحيبية خاصة بمعالج التصميم 


Layout Wizard E1‏ (المخطط 
Layout Welcome to the Layout Wizard!‏ ( 
Iji wizard alos you to quickly and early lay ou lhe‏ (فنضغط 
The wizaed wl display the ems in a frame on a canva.‏ التالی) 
arnıd lay them out in one of several styles.‏ 
Cšck Next lo begin cıeatîrıg your fsame.‏ 
TTT‏ فتظهر شاشة 
تحديد نوع ال( 
الورقة او 
e |‏ [ س )| سن | ضيبت _| يناه القماش 


56ع) وهناك 
خمسة أنواع 


(سندرسها لاحقاً بالتفصيل [المحاضرة الثامنة]) 


Content 

Stacked 

Vertical Toolbar 
Horizontal Toolbar 
Tab 


ORACLE 


× 


Display: 
¥ Current user ¥ Tables 
FF other users FT Yiews 


I Synonyms 


| س _ | س 


(حالا نجعلها على النوع الإفتراضي ٤)٥۸ ٣٤‏ تم نضغط التالي) 
في الشاشة التالية لها تظهر الحقول في ال (اءأا) فنختار منها الحقول المطلوب إظهارها في النموذج 


بواسطة الأزرار < » << . > . >> (يفضل 


8 = 
هنا إختيار حميع الحقول وإذا أردت 


[Layout wizard ||| aS. ut [Layout wizard ||| aS. 


Select the canvas on which you vwish to lay out the data 


فيما بعد إخغفاء أحد هذه الحقول فیتم EE E E also be‏ 


appropriate Canvas ype. 


ذلك عن طريق إعطاء القيمة No‏ 
لخاصية الرؤية مءاطآء۷i‏ التابعة له ثم 
نضغط التالي) 


- 


[Layout wizard ||| o. Wizar' [Layout wizard ||| o. 


يمكننا في هذه الشاشة تغيير العناوين ا× 


الظاهرة 


عرضها ۷۷ وطولها ۳ (تم نضغط التالي) 


تظهر شاشة تحديد طريقة عرض كتلة 
البيانات هل ستكون : 


(حالیاً سنختار ۲ھاuطھ٣‏ ثم نضغط 
ا 


Erier a ble for the frame. RE 
nuımbes of database tecotds to و‎ 


between 


To E Oa E DES RS used to 
O E BoE 
Frame Lille: [SruoenTs 
Recoeds Displayed |5 


Distance Between Recotds: 2 


recotds, check the Display 


I Display Scrolbas 


| نمهية _[ شعي ]| سبق | تسيمات  |_‏ إلفاء 


لأسماء الحقول اأام "ه٣۲‏ وكذلك 


۴۳ : عندما نرید أن يحتوي 
النموذج على عدد من الكائنات مثل 
List item « Display item «. Text‏ « 
E ... « Radio Group . Image item‏ 
إلخ 

BR BE SE عندما نرید ان تظھر‎ : bu 


البيانات على شكل سجلات . 


as well as the dslance 


| ية _[ دستي)| سبق 


التالي) 


في هذه الشاشة نحدد : 


« (Frame) pمpw|إ‎ ° 


ORACLE 


Layout Wizard 


Layout Wizard 


› )1 وعدد السجلات الظاهرة (الإفتراضي‎ ٠ 


وا افة بين السجلات مقدرة بالبيكسل اعء×آ۴ (الإفتراضي 0) . 


وهل نريد عرض شريط التمرير بجوار البيانات أم لا ؟ ( حالياً سنقوم بكتابة كا" ٠لںاك‏ كإسم للإطار » 
وتحديد عدد سجلات ظاهرة ب( 5 ) . وتحديد المسافة بين السجلات ب( 2 ) بيكسل ء وتنشيط 


عرض شریط التمریر » ثم نضغط 


Layout Wizard × الا لېی)‎ 
Congratulations! ظمٍ اة التهاني والتبريكات‎ i بعدها‎ 
You have finished describing your layout frame. ۴ 
1o mele e nev Kare and ly o ihe selected en لتعلن عن إتمام معالج‎ congratulations 
E التصميم (المخطط) بنجاح . (فنضغط‎ 
rela haem arrest نهاية)‎ 
yout Editor. To modfy the layout in can 
recall Ihe Layout Wizaıd Simply select the frame in the 
Layout Editor and choose Layout Wizard’ from the 

وبذلك نکون فد فمنا بتشغیل ۴0٥۲۳۹‏ 

e TE EE O a . Builder 
EE Editor and choose Properly Palette’ from the 

[ سي | ردت _| سبد_ | سيت _ | بف _ 


| qlyonawiOnotmail et) 


حاضرات فی اوراکل دىفلویر أ6 


2 
که 


الشاشات الرئيسةللر ۴0۲۳ 


: (Builder 


: Object Navigator .1 


ويحتوي عناصر النموذج كاملة ۴١۲١‏ وكذلك الكائنات 


Layout 


ئعزط0 . ومن الممكن الحصول على هذه الشاشة من Editor‏ 
خلال الضغط على الزر ۴3 أو من القائمة ا٥٥۲‏ نختار 
Jlٺمر Object Navigator‏ . 


.2 


: Layout Editor 
ويحتوي الورقة أو القماش كه۷١هK والعناصر المتوضعة‎ 


عليه » ومن الممكن الحصول على هذه الشاشة من 
خلال الضغط على الزر ۴2 أو من القائمة كا٥ه۲‏ نختار 
lمر Layout Editor‏ . 


.3 


: Property Palette 


Menu 
Editor 


ORACLE 


Object Property 
Navigator Palette 


Form Builder 


PL/SQL Design Tools 
Editor 
Object 
Library 


وتحتوي خصائص العناصر والكائنات كاءعزط0 . ومن الممكن الحصول على هذه الشاشة من خلال الضغفط 
على الزر ۴4 أو من القائمة ڪا10o‏ iخliر‏ لمر Property Palette‏ . 


0ازعzاأ نبذلةمبسطةعن محتويبات‎ 
: Navigator 
: Forms 


. [حالياً E1اMODUL‏ ] : إسم ال )۴٥١١۳(‏ الإفتراضي ويأخذ إسم 


البرنامج دوماً > 


. ۲ersوو"‏ : وهي عبارة عن (ا1/5Qا۴‏ , اSQ)‏ ینفذ عند حدتث 


معين › 
A‏ : وهي عبارة عن الرسائل » 

» وهي عبارة عن مکتبات ا@۴1/5‎ : Attached Libraries 

)ocاb Data‏ : وهي تحتوي الکتل والتي إما ان تکون 0(8 وهي 
التي تعتمد على جداول او مشاهد من ال( €٤25طةاة0)‏ او قد تكون 
8 وهي كتل التحكم التي لا تعتمد على ال(عكةطهأة0) » 
Canvases‏ : وهي الخلفية او القماشية (الورقة التي ترسم عليها 
العناص) » 

Edt‏ : ويمكنك من خلاله إختيار محرر النصوص الذي تريد 
إستخدامه › 

6 : وهي عبارة عن قائمة مركبة تقيم حقل معين من 
(Database)Jl‏ « 

Groups‏ ectز0b‏ : وهي عبارة عن تجميع للكائنات في مجموعة 
واحدة لنتجنب بذلك التكرار أتناء العمل خاصة في عمليات النسخ 
واللصق ٤‏ 


Parameters.‏ : مهم جداً عند إرسال قیم مع (النموذج )۴١۲۳‏ إلى 


Forms 
E JE MODULE1 
1-Triggers 
“Alerts 
I» Attached Libraries 
I-Data Blocks 
E--ffğ STU 
O-- Triggers 
FH Items 
O-- Relations 
Canyases 
5-Ê CANYAS2 
E1“ Graphics 
FRAMES 


Editors 

LOYs 

Object Groups 
Parameters 
Popup Menus 
Program Units 

I -Property Classes 
“Record Groups 
Reports 

I-Yisual Attributes 
I: Windows 
I:Menus 

PL#SQL Libraries 

Object Libraries 

Built-in Packages 

I -Database Objects 


EO OOOO 


E E-OI-I-{ 
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حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


» 10۷s نحتاج لإستخدامھا مع‎ : Record Groups .14 

Reports. 15‏ : لإنشاء التقاریر › 

Attributes. 16‏ اVisua‏ : يستخدم لإنشاء مجموعة خصائص مرئية › 
WindoNs.17‏ : یستخدم للتحکم بالنوافذ › 


› نحتاجها عند التعامل مع القوائم (حيث تخزن في ملف مستقل)‎ : Mens» 
» ۴1/؟Qا وهي عبارة عن مکتبات‎ : P]/SQ1 Libraries 

» 02 ٤اع وهي عبارة عن مكتبات تتبع الكائنات الموجودة في‎ : Ob[زect‎ Libraries 
› وهي عبارة عن الحزم المدمجة مع ال(عاءة0۲)‎ : Buiاt-in‎ Packages 

Database Objects‏ : حیت تقوم بعرض جمیع مستخدمي قاعدة البیانات 


2 


الحفظ والتتفيل في برامج Developer 6i‏ : 


الكائن عند عملية يتولد ملف ذو إمتداد 
برنامج 
عSav‏ الحفظ 50u ce‏ مصدري Form Builder *.FMB‏ 
Forms‏ | لنماذ ج EEE‏ : ی ی یی یی ی و و ھی و چ چ ى چ 
eااCmpP‏ الترجمة Execute‏ تفیذي Forms Runtime *,FMX‏ 
Save‏ الحفظ 50u ce‏ مصدري Form Builder *.MMB‏ 
M enu‏ | لقو | نم CECE‏ یی ی ی ی ی ھی ی ی ی ی یی یی و ن ی ى ب ن 
eااmpP€‏ الترجمة عEX×ecutتفیذي Forms Runtime *.MMX‏ 
مSav‏ الحفظ 50u ce‏ مصدري Report Builder *.RDF‏ 
Reports‏ التقاریر TT Sana a I TSS‏ 
eااmpP€‏ الترجمة Execute‏ تنفیذي Reports *. REP‏ 
Runtime‏ 


طبعاً يعطى الزبون الملف التنفيذي عااءع×۴ ويبقى الملف المصدري 501۲٤١8‏ مع المبرمج › 


حيث يستطيع التعديل في البرنامج ولا يستطى التعديل في التنفيذي . 


TT 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


ه. عند رسم أي أداة (كائن) لابد أن يوضع على 3١۷25‏ وإلا فإن المترحم سيعطي رسالة خطأ بأنه غير 
قادر على التنفيذ . 


۵. عند تنفيذ البرنامج نلاحظ وجود شاشتين : 
Forms Runtime‏ « 
WINDOW1I‏ „ 
.C‏ 


في وضع التنفيذ يمكن إجراء (إدخال الإستعلام) وكذلك (تنفيذ الإستعلام) والتنقل بين السجلات 
۵. لترجمة البرنامج نتبع الخطوات التالية : 


File > Administration > Compile File 
. ])*.۴M×(لا وبالتالي يتم الحصول على النسخة التنفيذية [ملفات‎ 


Kz لداواے‎ 


n. 

إجراء تحرير استملام تطمة سمجل حتل نانذة تطيمات 

SEI D> a OB aX FF BQ 

ا×اوا۔ 2 

TUDENTS 

رتم الطاب اس لات رتم ارتم الممترى 

1 جال مهیر 1 ٤‏ ] اررفا 

۲ عبداقرحمن عبداقولي 1 ٤‏ | رانا 

۴ عبدالمزیز شاف 1 ) ]| التصر 

G‏ حمد منصور 1 | قهري 

0 بسام عبد الطب ٤ Jı‏ ] ضر 

ت 

اا ا 
صجل: ٩/۱‏ 


TT 


حاضرات فی اوراکل دىفلویر آ6 


اأحاضرة الخالشة 


*٭ من خصiانiص MODULE‏ : 
Menu Module .1‏ : 
وتعني تحديد القائمة الرئيسية التي تريد إستخدامها عند 


تنفيذ البرنامج » (فمن المعلوم أن القوائم في ءا٤0۲‏ تأخذ 
ملفا مستقلاً كما ذكرنا ذلك سابقاً) » والقيمة الإفتراضية 
لهذه الخاصية هي DEFAULT &SMART8AR‏ أي القائمة 
التي تظهر في شlشة Forms Runtime‏ .„ 


Action Edit Query Block Record Field Window Help 


ZêEJ HB BEA EEĞ Ab FFA (2 


: Defer Required Enforcement .2 

وتاخذ القيمة الإفتراضية ۸٠‏ وعند جعلها ء۲۴ فإنها تقوم 
بتجاوز القيود المنشئة على الحقول كصع)! . 

Direction .3‏ : 
وتعني تحديد إتجاه القراءة والكتابة للنموذج ۴0۲۳ وتاخذ 
هذه الخاصية القيم الثلات الآتية : 

Rمقiك۲۷ وتكون حسب اللغة المحددة في‎ : Default .a 
8 Start > Run > RegEdit 


وعد الدخول إلى محرر ال(5†۲أوه#) نتبع التسلسل الآتي 


ZZ HKEY_LOCAL_MACHINE 
3 77 SOFTWARE 


3 77 ORACLE 


ni@notnail ¢0 


ORACLE 


MODULE 


MODULE 
WINDOW 

File 
DEFAULTSSMARTEAR 


Pull-down 
No 


Form 


<Nullz 


<ul> 


Default 

Blocking 

0 

0 

Read Committed 


es 
<ul> 
<ul> 


Default 


5,0 


# General 
a Name 
o Subclass Information 
o Comments 

# Functional 
a Title 
a Console Window 
a Menu Source 
a Menu Module 
a Initial Menu 
a Menu Style 


a Defer Required Enforcement 


a Menu Role 
# Navigation 

a Mouse Navigation Limit 

a First Navigation Data Block 
#7 Records 


a Current Record Visual Attribute Gri 


# Database 
a Validation Unit 
a Interaction Mode 
o Maximum Query Time 
a Maximum Records Fetched 


a Isolation Mode 


a Coordinate System 
a Use 3D Controls 
a Form Horizontal Toolbar Canvas 
a Form Vertical Toolbar Canvas 
# International 
a Direction 


# Compatibility 


a Runtime Compatibility Mode 


1 17 
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# Menu Security 


& Physical 


حاضرات فی اوراکل دىفلویر أ6 


3 77 HOMEO 


> %3 NLS_LANG 
[National Language 
Standard_LANG] 


فقيمة ال(ةاة0 عuا۷a)‏ التابعة 
لل( ۸6 Aا_N15)‏ ستأخذ أحد 


ARABIC_UNITED 
ARAB 
EMIRATES.ARSMSWI 
N1256 

ARABIC_SAUDI 
ARABIA.ARSMSWINT 
256 


ا×اھاے 


Data 

(value not set) 

C:lorant}DBS 

G5A 

0 

ARABIC_UNITED ARAB EMIRATES. ARBMSWIN1 Z56 
Oracle for Windows NT 

C:lorant 

DEFAULT _HOME 

C:lorant 


ORACLE 


|_Type 

REG_SZ 

REG_EXPAND_SZ 
REG_EXPAND_SZ 
REG_EXPAND_SZ 
REG_EXPAND_SZ 
REG_EXPAND_SZ 
REG_EXPAND_SZ 
REG_EXPAND_SZ 
REG_EXPAND_SZ 


Name 

lab] (Default) 

a] API 

lab] COMPANY_NAME 


labÞÎNLS_LANG 
laB]ORACLE_GROUP... 
lab] ORACLE_HOME 
laB]ORACLE_HOME_... 
lab] SHARED_ORACLE... 


zm E 


NLS_LANG 
Value data: 


[AMERICAN_AMERICA. WEBISO8859PI 


Cancel 


Re E ew Fave 1elp 
Z1} My Computer 5 
F-@D HKEY_CLASSES_ROOT 
*1-B) HKEY_CURRENT_USER 
&-@ HKEY_LOCAL_MACHINE 
1-1 HARDWARE 
2-J sam 
O securıry 
A-@ SOFTWARE 
- N Adobe 
H-@ Ahead 
BN Apple Computer, Inc 
H-{ğ Avance Logic, Inc. 
& Ses 


A-O es 
-OD INTEL 
(O Internet Download 


-@ ORACLE 
Ê ALL_HOMES 
E: Backup 
 HOMEO 


1-Ê] ORACLE_HOMES 
OM secuRrIry 
*1-@] SMPDaemon 
#-@) software a = 
1 


مما يعني أن اللغة الإفتراضية هي العربية وبالتالي تصبح القيمة الإفتراضية هي (ا€۴ا ٠٠‏ خ9أR)‏ » 


مع ملاحظة أنه يتم تحدد نوع اللغفة العربية المنتقاة (إماراتي - سعودي ... إلخ) أثناء عملية تثبيت عا٣0۲۵‏ › 


٤ 


أو القىمة التالية : 


AMERICAN_AMERICA.WESISOSS59P!I °‏ 
مما يعني أن اللغة الإفتراضية هي الإنجليزية وبالتالي تصبح القيمة الإفتراضية هي (ا٣9أR ۲١‏ 16۴) . 


. من اليسار إلى اليمين‎ : Left o Right .b 
. من اليمين إلى اليسار‎ : Right To Left .c 


9 


: Triggers الأحداث‎ 


وهي عبارة عن شفرة مصدرية C048‏ تكتب ب(ا@۲1/5 ; ا5Q)‏ وعلى ثل 


مستوی النموذج مeاuں‌dہM‏ ) منھا: 
WHEN-NEW-FORM-INSTANCE‏ : ينفذ عند بدایة تحمیل ال(۲۳٥۴‏ 
. مستوى كتلة السانات )ها8 ٥a†a‏ ) منها : 
WHEN-NEW-BLOCK-INSTANCE‏ : ینفذ عند بدایة الدخول علی ال 
WHEN-NEW-RECORD-INSTANCE‏ : ینفذ عند بدایة الدخول علی 


., )Bاه‌c)k(لا ینفذ بعد الدخول على‎ : P051-BL0€CK 
: منھا‎ ) 1tem توی الى‎ َ 
› ينفذ عند بداية الدخول على ال(۳عا!1)‎ : WHEN-NEW-ITEM-INSTANCE 
« PUSH BUT ON ينفذ عند النقر على العنصر‎ : WHEN -BU 1 ON -PRESSED 
› ینفذ عند التعدیل على العنصر ۴۳( ااا‎ : WHEN_LIST_CHANGED 


1 
2 
PRE-BLOCK‏ : ينفذ قبل الدخول على ال(۸٤810)‏ > 
3 


WHEN_IMAGE_PRESSED‏ :ینفذ عند الزة 


mail 


کا ار Image‏ . 


۸ 18 
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-1- J MODULE1 
a 
J-Alerts 
-Attached Libraries 
FI-Data Blocks 
~î 51 
TClriqgers2 


K-Items 


EF S1 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


# الرسائل: 
بالطبع ليس المهم أن نكتب الرسالة ولكن المهم معرفة : 


› (Alert وİ‎ message ما هو غرض الرسالة (لتحديد نوعھا ھل هو‎ ٠ 

۰ واين سنكکتبها (في اي حدث 1۲|99€6۲) . 

أنواع الرسائل : 

message .1‏ ) وهي الرسائل التي تختص بالظهور على شريط المعلومات (شريط الحالة) » وتأخذ الصيغة 
العامة التالية 

'( نص الرسالة;‎ message) 


ا منا ذلك : 


ولعمل ذلك نحتاج أولاً لمعرفة ال (6۲وو١٣۲)‏ الذي نريد تنفيذ أمر إظهار الرسالة عنده فبعد تحديد العنصر 
٤‌NAM_لS۲‏ نقوم بالنقر على زر الفأرة الأيمن لنختار الأمر WHEN-NEW- ثjدحll aiمو Smart Trigger‏ 
ITEM-INSTANCE‏ لنكتب فيه İمر‏ llلرllwة message (' Please.. Enter Name of Student?‏ 
۽ (' ثم نضغط على الزر ماام C٥"‏ لنتأكد من أنه تم ترحمة الأمر بشكل صحيح لهذا الحدث › 


ونلاحظ عند تكرار عمل الرسالة الخاصة بال(6وة5ءكئه") مرتين أنه قد تم تحويل الرسالة الثانية تلقائياً إلى ما 


Name HEN NEW ITEM IRS TANCE 


0 
Na a xt Suse hy Comcaod 
Mea UST _ Fir tp edo Deve SNUETUST mb! | a UF Fie My Osocie DevelogecSijê jT nê 


2. erاA)‏ وهي الرسائل التي تظهر بشکلٍ صندوق حوار 
والتي قد تكون رسالة من النوع (إيقاف مها أو تحذير C0١‏ أو ملاحظة (Note‏ 


وقد تحتوي على ( زر أو زرين أو ثلاثة على الأكثر) إلى غير ذلك من خصائص صناديق الحوار ... وكمثال على 
ذلك ٤‏ 


حاضرات نی اوراکل دىفلویر أ6 


ه. مرحلة إنشاء الرسالة : 


ORACLE 
وإذا نقر الزر (موافق) يقوم بحذف السجل ويحفظ ؟‎ ٠ فإذا نقر الزر (إلغاء الأمر) يخرج بدون الحذف‎ 


وفي 0۲٤18‏ يمكن عمل مثل هذه الرسائل ولكن على مرحلتين : 


حيث نقوم بتحديد ال( ٤۲ها۸)‏ الموجود في شاشة ال( 0۲اNaviga‏ ectز0b)‏ تم Create‏ لینشی لنا إسماً 
إفتراضياً للرسالة المنشئة فنحددها ثم نضغط ۴4 للتحكم بقيم الخصائص الهامة التابعة لها وكالتالي : 


Value 


Del 


موافق 


ا. مرحلة طلب الرسالة والمعالجة: 


حذف سجل 
هل ترید حذف السجل بالتأكيد ؟ 


Stop 


إلغاء الأمر 


Button2 


Property 

1 Name 
2 Title. 
3__ Message 
4 Alert Style | 
e TT 
[ 6 Button 2 Label 
7 Default Alert Button 


ولعمل ذلك نحتاج لمعرفة ال96 وآ٣٣)‏ الذي نريد تنفيذ أمر إظهار الرسالة عنده فبعد تحديد ال( ة0 
)ocاBl) S۷‏ لأنه وكما هو معلوم أن عملية حذف السجل تكون على مستوى كتلة البيانات)٤8|0 0a‏ » 
نقوم بالنقر على زر الفأرة الأيمن لنختار الأمر ۲١996‏ 5۳2۲ ومنه الحدث ۴1۸۴٩‏ ۴۷-9 × لنكتب فيه أوامر 
معالجة الرسالة وكالتالي : 


glyahaniOhotnailt\ 


Number ; 


ow_ Alert ('Del') ; 


= Alert Buttonl Then 


ete_ Record ; 


Declare 


N 


Begin 
N := Sh 
If N 


Del 


Commit ; 


7 


r 


Else 


Nul 


End If 


End 7 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


ثم نضغط على الزر هاام"C0‏ لنتأكد من أنه تم ترجحمة الأمر بشكل صحيح لهذا الحدث » وليتم التنفيذ من 
خلال القائمة التي تظهر في شاشة ع٣‏ ٤٣ں" ۴٥۲۳‏ . ولكن إذا أردنا تنفيذ أمر الحذف هذا من خلال زر 
يقوم بعملية الحذف فنتبع الخطوات التالية : 


1. ننشئ زر ليقوم بعملية الحذف وذلك برسمه على ال(۷25١C3٤)‏ ونعطيه الخصائص : 
Property Value‏ 


1 Name DL 
٤ ا€عط2ا ا2‎  فذح‎ 
i TTT aS 1 


2. نقوم بنسخ ما کتبناه في الحدث ۸۴۷-2٤1۸٤٣٤‏ إلى الحدث الخاص بال( ١٣٥ا )Pus۸-Bu‏ عن طریق 
إختيار الأمر WHEN-BUTTON-PRESSED jڏzJl aio Smart Trigger‏ من خلال : 

ه. تحديد العنصر 1ا0 من شاشة 0۲أةوااة. زط0 والنقر على زر الفأرة الأيمن › 

. تحديد الزر حذف في شاشة Editor‏ Leyoutا‏ والنقر على زر الفأرة الأيمن › 

. ۴۲09۲2۳ عند تحديد العنصر ا0 أو تحديد الزر حذف من القائمة‎ .٤ 
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: Data Blocks كتل البيانات‎ 


+ مكونات ال()عه‌ا8 هغه0 ) الأساسة : 

ه. sاeووناآ‏ : وهي الأحداث المتعلقة بال()ع ها8 هاة0) [المستوى الثاني من ال(كئ۲عووة٣١)]‏ » 

ط. tems‏ : وتمتل العناصر التابعة لهذا ال()٤0ا8‏ aة0)‏ [مثلاً : حقول الجدول وعناصر التحكم التابعة له] › 
Relations .c‏ : لربط هذا ال()Bloc )Data‏ مچ أي ()ocاB )0ata‏ آخر [مثلاً : ربط جدول مچ جدول آخر] . 


۰ Data Bloc 1 سے‎ * 
ِا‎ 


حاضرات فی اوراکل دىفلویر أ6 
وليكون العمل أكثر أمنية . 


Navigation Style 


Block 


Database Data Block 


ORACLE 


شرح مبسط 


والذي سيتم التعامل من خلاله مع ال9٥‏ 0ا8 aاة0)‏ برمجياً 


تحديد كيفية إنتقال المؤشر ولها ثلاتة قيم : 


: Same Record (A 


وتعني التنقل بين حقول نفس السجل من أول حقل إلى آخر 
حقل 


بحيث يظل المؤشر على نفس السجل وليتم التنقل بين حقول 
هذا السجل بضغط ۲٤ا٣۴‏ ۽ 


Change Record (B‏ : وتعني تغير السجل الحالي 


بحيث يتم انتقال المؤشر من آخر حقل للسجل الحالي إلى 


Change Data Block (C‏ : وتعني تغير ال(K٤٥ا8)‏ الحالي 


بحيث يتم انتقال المؤشر من أخر حقل للسجل الحالي في 
ال(۸عهاB)‏ الحالي إلى أول حقل في ال()٤ها8)‏ التالي . 


تحدید ال(810C)‏ ال 


3 الترتيب الإفتراضي حسب شاشة 


EEOC 


تحديد نوع ال()عها8 ه0at)‏ وتمتلك القيم(N.0‏ , كم۷) 


(Yes) : Database .1‏ 
آي المرتبط مع قاعدة البيانات (الجداول والمشاهد والمرادفات 


...إالخ) » 


(No) : Non Database .2‏ 
اي المعتمد على عناصر التحكم فقط و لا يعتصٍ على قاعدة 
البيانات )0DUMMY(‏ . 


حاضرات فی اوراکل دىفلویر أ6 


11 


12 


13 


Insert Allowed 


Update Allowed 


Delete Allowed 


ORDER BY Clause 


ORACLE 


سماحية الإدخال للبيانات أثناء التنفيذ وتمتلك القيم , ك۷6) 
No)‏ 


سماحية التعديل على البيانات أثناء التنفيذ وتمتلك القيم ۷65) 
No)‏ , 


سماحية الحذف من البيانات اتناء التنفيذ وتمتلك القيم , ك۷6) 


No) 
: ك ملاحظة هامة‎ 


صلاحية ال(ا50) أقوى من صلاحية #۲م٥اع0e۷‏ وكمتال على 
ذلك : 


SQL> revoke delete on STU.LvI from UST ; 


تعليمة ال(501) هذه ستسحب صلاحية الحذف على الجدول 
ا۷ا من المستخدم اك في أي برنامج » أما في ۲ۃeصDevelop‏ 
فإنه إذا تم إعطاء القيمة Delete Allowed ةيصlختنل N0‏ 
فستمنع الحذف من الجدول ا۷ا ضمن البرنامج الحالي فقط 
وعند إنشاء برنامج آخر فإنه يمكن الحذف من الجدول ا۷ا إذا ما 
تم إعطاء القيمة ۲١‏ للخاصية ٤٩4‏ W٣٥ااA‏ عاعا0e‏ ما لم تكتب 
تعليمة ال(5@1) أعلاه وإلا فلا جدوى من قيم هذه الخاصية من 
سماحية للحذف ب(۲e5)‏ أو منعها ب(ه١)‏ . 


شرط جلب السجلات من الجداول 


| تحديد الخفل المراد الترنيب هن خلالة وكعية الريب أمتلة ` 


ذلك : 


: Lv_Name 
يتم الترتيب حسب الحقل إسم المستوى تصاعديا‎ 
(الإفتراضي)‎ 


: Lvl_Name desc 


يتم الترتيب حسب الحقل إسم المستوى تنازلياً 


: Lvl_Name ASC 
يتم الترتيب حسب الحقل إسم المستوى تصاعدياً‎ 


LIT 


ٍ 

ORACLE o 
: Visual Attribute *٭ الخصائص انمرئنية‎ 
: في جدول ساك بشكل مختلف عن بقية السجلات وكالتالي‎ u٣ ٣خ‎ ۸٥٣0۲١ مثال : مطلوب إظهار السجل الحالي‎ 
؟‎ Red خلفية بلون ٣۵ر٤ » خط نوعه اھ۸ بحجم 12 وبلون‎ 
: وليتم ذلك لا بد من المرور بمرحلتين‎ 
: ه. مرحلة إنشاء الخصائص المرئية‎ 
لینشی لنا‎ Create حیث نقوم بتحدید ال(عاuط!Attr اVisua) الموجود في شاشة ال(0۲اaوNavi tغecز0b) تم‎ 
: إسماً إفتراضياً للخصائص المرئية المنشئة فنحددها ثم نضغط ۴4 للتحكم بقيم الخصائص المطلوبة وكالتالي‎ 
Property Value 


1 Name VA1 


2 Visual Attribute Type | Common 


3 Foreground Color 1 Red 1 
2 
: e a 
س‎ 3 


ا. مرحلة طلب الخصائص المرئية : 
ولعمل ذلك نحدد ال(۸٤0ا8‏ هغة2) S۲۷‏ ثم نضغط ۴4 لنتحكم بالخصائص المرئية وكالتالي : 


Property Value 


Current Record Visual Attribute Group VA1 


2 


: العناصر كصع]ا|‎ 
: وتنقسم إلى نوعين‎ 
. Radio_Group « Check_box « List_Item « Text_item : Jie : Input Items ةıllخدإ‎ رصاiنغ‎ .a 


. Images . Push_Button « Display_ltem : Jie : Non Input Items ةıllخaإ‎ J رصاiع‎ .b 
تشترك هذه العناصر ببعض الخصائص ونختلف في الخصائص الأخرى‎ 


LLI 


حاضرات فی اوراکل دىفلویر أ6 


0 


*٭ خصائص ”te|ا 1x‏ : 


Name 
Item Type 
Enabled 
Justification 
Data Type 
Maximum Length 
Initial Value 
Required 
Format Mask 
Database Item 
Query Allowed 
Insert Allowed 
Update Allowed 
Visible 
Canvas 
X Position 
Y Position 
Width 
Height 
Font & Color 


Prompt 


Prompt Font & Color 


شرح مبسط 


والذي سيتم التعامل من خلاله مع ال(8۳اآ_×6٠)‏ برمحياً 


ORACLE 


25 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


٭ خصائص ”۴ ]| اوا : 
Element in List 1‏ | لتحدید العناصر المحتواة مع قیمھا 


*% نص Check Box‏ : 
Yalue When Checked 1‏ | قیمة العنصر عندما یکون محدد (منشط) 


Check box Mapping of Other Value 3‏ | عند وجود قيمة مغایرة لقیمتین السابقتین 


وتكون القيمة المغايرة عادة موضوعة في عںاج۷ اها†آہ1 


بقية الخصائص كما مر سابقاً 


* خصiiأصض Radio Group‏ : 
وهي تحوي العدید من t٥٣‏ 8u_هالهR‏ أي أنها بمثابة الحاوية۲٠١‏ اه٤‏ للخيارات المفردة 


2 


Mapping of Other Values 1‏ | عند وجود قيمة مغايرة لقيم العناصر المحتواة 


Initial Value 2‏ القيمة الإبتدائية للعنصر 


بقية الخصائص كما مر سابقاً 


: Radio Butt0¬ خصائص‎ 
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حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


۰ 


Radio Button Value 2‏ | القيمة الخاصة بالعنصر 


بقية الخصائص كما مر سابقاً 


*٭ خحصائص Display Item‏ : 
كل الخصائص قد مرت سابقاً ولكن نستفيد من هذا العنصر أنه لا يمكن التعديل فيه ولا ينتقل إليه التركيز 


Focus 
: Push Button ٍصiliaخ‎ * 
ا شرح مبسط‎ 
امطه ا | العنوان الظاهر أمام المستخدم‎ 1 
O O TT 
n I TT TT OTE TT 


بقية الخصائص كما مر سابقاً 


٭ خحصائنص ععةصا| : 
الخاصية شرح مبسط 


Image Format 1‏ نوع الصورة 


mage Depth 2‏ _-_ عمق الصورة ا 


Sizing Style 3‏ تحديد نمط التحجيم (قطع - ملائمة) 


بقية الخصائص كما مر سابقاً 


„9 lahawiOnotmailcy) 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


# التحكمبالخصائص برمجياً: 
عن طريق التعليمةا56 نستطيع التحكم بخصائص الإسهل"W1)‏ أو ال()عها8) أو ال("8ا]) أثناء تنفيذ البرنامج 


في لوحة الخصائص اا۴ أاهمهإ۴ نستطيع التحكم بالخصائص في مرحلة تصميم البرنامج . 
والصيغة العامة كما يلي : 


للتحكم بخصائص النافذة )رأاع5et_Window_Propإسم‏ النافذق إسم الخاصية ,قيمة الخاصية ( 
برمجياً ; 


للتحكم بخصائص الكتلة برمجياً )رأ#۲م۲۲0_)عها8_اه5 إسم الكتلة , إسم الخاصية ,قيمة الخاصية: ( 


(t_1tem_PropertyعSإسم‏ العنصر إسم الخاصية ,قيمة الخاصية ; ( 


٠ه‏ عند تحميل البرنامڇ ؟ : حڌٽثWHEN_NEW_FORM_INS7ANCE‏ « 
هه في زر ... ؟ : حڏدi èl| ... WHEN_BUTTON_PRESSED‏ . 


1 التشحكمبخصائص النافذة 0WلWi۸ rE‏ ؟ 
وكأمتلة على ذلك : 


* تکبیر نافذة (Forms Runtime)‏ ؟ 
Set_ Window Property (Forms Mdi Window , Window State , Maximize);‏ 


لاحظ أن إسم نافذة ال(٥‏ ٣٤ہ )۴٥ms Ru‏ اسم ثابت دائماً فھو یکتب ۴0۲۳5_Mdi_W ۸0W‏ ومن غیر إِشارات 
الإقتباس . 
إقتباس 


# تكبير نافذة البرنامج إلى حجم نافذö (Forms Runtime)‏ ؟ 


Set_ Window Property ('Windowl' , Window State , Maximize); 


لاحظ أن إسم نافذة البرنامج إسم متغير فهو يكتب حسب إسم النافذة البرمجي ومع وجود إشارات الإقتباس 


° 


# تغيير عرض نافذة البرنامج بإرتفاع 600 وعرض 800 ؟ 
ا , Set _ Window Property('Windowl' , N 600 , Width‏ 

IawiOhotmail 
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2 
محاضرات ف أُوراکل دمنلور 6 ORACLE‏ 

# إعطاء عنوان ' برنامج الطلاب ' لنافذةö (Forms Runtime)‏ ؟ 

'( الطلاب;‎ جمانرب5Set_Nindow_Property‎ (Forms _Mdi Window , Title , ' 

لاحظ أن الخصائص عندما يكون لديها قيم محرفية فلا بد من وجود إشارات الإقتباس . 


إعطاء عنوان ' بيانات المستوى ' لنافذة البرنامج ؟ 
Property ('Window1' ,Title ,‏ _set_Nindowبیانات‏ المستوی; (' 
#* تصغير نافذة البرنامج وكذلك تصغير نافذةö Runtime)‏ Forms(؟‏ 
Set _ Window Property ('Windowl' , Window State, Minimize);‏ 


Set_ Window Property (Forms Mdi Window , Window State, Minimize); 


2. التسشحكم بخصائص الكحتلة E EE Block‏ 
وكأمثلة على ذلك : 


# السماح بالإستعلام من جدول المستويات v1‏ ] ؟ 
Set_ Block Property('Lvl' , Query Allowed , Property True);‏ 


لاحظ إعطاء القيمة ع٥٠۷ا١۲١_۷أ۲عمه۲م‏ عندما تكون قيمة الخاصية ۲65 . 


منع الإستعلام عن جدول المستويات آ1 ؟ 
Set_ Block Property('Lvl' , Query Allowed , Property False);‏ 


لاحظ إعطاء القيمة عكاة۴_رأاممهام عندما تكون قيمة الخاصية ١0٥‏ . 


* ترتيب جدول المستويات 1.1 بحسب الرقم ؟ 
Set _ Block Property('Lvl' , Order By , 'LIvl No');‏ 


ترتيب جدول المستويات 171 بحسب الإسم ؟ 
Set Block Property('Lvl' , Order By, 'Lvl Name');‏ 


وكذلك الحال بالنسىة لىقىة خصانص الكتلة )ها8 مثل : 


› الخاصة بالإضافة‎ : اnserا_A110wed‎ 
› الخاصة بالتعديل‎ : Update A1 1owed 
» الخاصة بالحذف‎ : Delete A1 10wed 
Where طرشJlب‎ ةصlëخl|l‎ : Defalut_Where 
Set _ Block Property ('Stu' , Defalut Where , 'Stu Sec >= 1'); 


Visual Attribute ةlتöكlJ الخاصة بالخصائص المرئية‎ : current_ Record Attribute 
Set _ Block Property ('Stu' , Current Record Attribute , 'VAl1'); 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


*٭ إظهار حقل إسم المستوى في جدول المستويات آ1 ؟ 


Set_ Item Property('LvLl _Name' , Visible , Property True); 


إخفاء حقل إسم المستوى في جدول المستويات 1v‏ ؟ 


Set_ Item Property ('Lvl Name' , Visible , Property False); 


* تنشيط (تمكين) حقل إسم المستوى في جدول المستويات ]vI‏ ؟ 


Set_ Item Property ('Lvl Name' , Enabled , Property _ True); 


* تبهيت (عدم تمكين) حقل إسم المستوى في جدول المستويات 1I‏ ؟ 


Lvl Name' , Enabled , Property False); 


Set _ Item Property ( 


وكذلك الحال بالنسىة لىقىة خصانص الكتلة )ها8 مثل : 


)× , الخاصة بتحديد موقع العنصر على نافذة البرنامج ب(۷‎ : sition 
, 100 , 100); Set _ Item Property ('MyButton' , Position 


Visua1 Attribute‏ : الخاصة بالخصائص المرئية للعنصر 
'VA1'); Set_ Item Property ('Stu_No' , Visual Attribute‏ , 


... إلخ . 


0 المتحولات العامة والمتحولات المحلية م 
1. المتحولات العامة Global Variables‏ : 
تبدأً ب).GIobal:(‏ 


ولتعريف متحولات عامة بحيث نستطيع التعامل معها بأي r€ھوrigل‏ أو Îي Function ¢يÎ sİ Procedure‏ 


نعرق المتحول العام في الحدتثت WHEN_NEW_FORM_INSTANCE‏ وحتی یصبح معروفاً لکامل 
(Forms)Jl‏ . 


والصيفغة العامة للتعريف كما يلي : 
عندما تكون القيمة الإبتدائية رÎpa‏ ; :global.Variable := Value‏ 
عندما تكون القيمة الإبتدائية نصا محرف ; :global.Variable := 'Value'‏ 


بالطبع يفضل دانماً أن نعطي فيماً إبتدائية للمتحولات تلافياً لحدوت أية مشاكل 


:Global.MyNo := 1 ; 


:Global .MyName := 'Amerah'; 


ء 
حاضرات فی اوراکل دفاور 61 ORACLE‏ 
يعني ضمن ال(”أوع8) وال(ك") المعرف ضمنها . 
والصيغة العامة للتعريف كما يلي : 
عندما تكون القيمة الإبتدائيöة‏ رقÎp‏ ; Variable DataType := Value‏ 
عندما تكون القيمة الإبتدائية نصا محرفً ; Variable DataType := 'Value'‏ 
بالطبع يفضل دائماً أن نعطي فيماً إبتدائية للمتحولات تلافياً لحدوث أية مشاكل 
كأمثلة ذلك : 
MyNo Number := 2 ;‏ 


MyName Varchar2 (20) := 'Gawaher'; 


° التحكمبالخصائص برمجياعن طريقا| ا لات العامة 
کر 
IFT‏ ت استعم تة تان 3 
نريد إنشاء زر عنوانه ' إخفاء ' وعند النقر اک ایا ا ا ا کلک ا ا ا 
عليه يخفي إسم المستوى ويتغير عنوانه إلى ' اک .ی ا ا 
إظهار ' سوچ حم و 
1 عم طاهر 1 [ 


e 


وعند النقر عليه مرة أخرى يظهر إسم المستوى 
ويتغير عنوانه إلى ' إخفاء ' 


وهكذا تستمر العملية بين " إظهار ' و ' إخفاء' 
؟ 


ENTER, VALUE OF NARE] 
٩۸ سج‎ 


(قم بربط قيم الخصائص البرمجية بمتحولات عامة) 


ولعمل ذلك لا ند من : 


۰ تعریف متحول عام (علی مستوی النموذج )۴١۲۳‏ وليكن × حيث نقوم بإسناد القيمة ' إخفاء' إليه كقيمة 
إبتدائية ونتحكم بكتابة عنوان الزر من خلال قيمة المتحول العام » 

ف خض يها لون الام ى جرت (الذع على اللي مى لال اة 1۳ الك طة ف كانت فة 
الحو ' إخفاء" فإننا سنخفي هذا العنصر بخاصية #اطءا ونسند القيمة المغايرة ' إظهار' إلى 


المتحول ail‏ يح ز 1 ته يوان الزر من 1 L1‏ العام الجديدة . 
0 8 31 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


' ;ءافخإ:G10طba1.×‎ := ' 


Set_ Item Property ('MyButton' , Label , :Global.X) ; 


WHEN_BUTTON_PRESSED .2 
' thenclêëخ|If‎ :Global.X = ' 


Set _ Item Property ('Lvl Name' , Visible , Property False); 


1 إظهار;‎ :Global.X := ' 
Else 
Set _ Item Property ('Lvl Name' , Visible , Property True); 
1 ; إخفاء‎ :Global.X := ' 
End if ; 


Set_ Item Property ('MyButton' , Label , :Global.X); 


| 


3 الترقيمالتلقائي : 
مطلوب : عمل ترقيم متسلسل لحقل رقم الطالب 51_٥٠‏ في جدول 5۲٦‏ ؟ مع إختیار ال ٣ ٣!عع e۲‏ المناسب ؟ 


e 
(يتم إفتراض أن قيمة الحقل للسجل الأول مهيئة بقيمة مدخلة من المستخدم ؟‎ 


a awONot ۳‏ 1 سی 
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(Trigger : KEY_CREREC)‏ 


حدث إنشاء السجل 
Declare‏ 
Counter number ;‏ 


تغرف تول . الغد اق من نوع رقي 


Begin 
Select Max (Stu _ No) into Counter From Stu ; 

إختيار القيمة العظمى من حقل الطالب وإسنادها إلى متحول العداد 
:Stu_No := Counter + 1 ;‏ 


ترقيم خقل .االطالك هة اللتخول ماقا إليه واحد 


End ; 
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: Relations العلاقات‎ 


هي تعبير يطلق على علاقة بين جدولين أحدهما هو الجدول الرتنننتى ٣هtكة]‏ والآخر هو الجدول 
التفصيلي كاأدخه . ولإتمام العلاقة بال خطو ات التالية : 


تحديد الجدول الرئيسي ۲عاكة«× والجدول التفصيلي كاأة†م0 » 


تحديد حقول الربط بين الجدولين (وتسمى الحقول المخفية) » 
تحدید شروط الربط بین الجدولين C010٩‏ "30 . 


ليكن لدينا الجدولين التاليين 


Master 
رقم الطالب إسم الطالب رقم القسم رقم المستوى‎ 
Details 
رقم المادة إسم المادة أعمال السنة النصفي النهائي‎ 
» نلاحظ من خلالهما أن جميع حقول الجدول الرئيسي متوفرة في جدول ا81‎ ٠ 


بينما نجد أن جميع حقول الجدول التفصيلي متوفرة في جدول MARK‏ . 


d 


d 


يتم الربط من خلال الحقول (رفم الطالب - رفم القسم - رفم المستوى) › 1 
شروط ربط الجدولين يحدد من خلال عدد الجداول لذلك سنحتاج إلى شرط ربط واحد على اقل تقدير ) 
( ۸-1 ولکننا هنا نجد ان شروط الربط هي : 

Mark.Mark Sec = Stu.Stu_ Sec An 


Mark.Mark_ Lvl = Stu.Stu_lLvl An 


Mark.Mark_ Stu = Stu.Stu_No 


: Data Block Wizard جJleمe طريقة‎ .1 

حیث نقوم بإانشاء ۴۵۲۳ تکون فيه ال ھا5 2 i‏ 
)ocاB‏ معتمدة على الجدول ل8۲۷ ولیکن 

بشکل ۲ھااطة۲ يحوي سجلا وحيدآً » و ووو ر و و ی ع 

كذلك إنشاء )عها8 هاة0 معتمدة على cee e ._ | ۸ E‏ 

TF auopin data boeks Tabular ولیکن بشکل‎ MAR) الجدول‎ 


يحوي خمسة سجلات › وأثناء إنشاء Deets Relaionhe_| Data‏ 


e0 


eti lem Master Item 
MARK_STU - RE -] 


Cn‏ ت 


حاضرات فی اُوراکل دىفلویر أ6 ORACLE‏ 
كتلة البيانات Data Bاoع) Wiad‏ نلاحظ ظهور الشاشة التالية : 
فنقوم أولاً بإلغاء الربط التلقائي بين الجدولين 
Auto-join Data Blocks‏ 


ثم نذهب للزر ...۸ك" 0ااaامR‏ مeatاC‏ لنحدد من خلاله الجدول الرئيسي ل5۲ أما الجدول التفصيلي 
MAR)‏ فهو محدد تلقائياً بسبب أننا قمنا بتحديد العلاقة من خلاله ونحدد شروط الربط من خلال إنتقاء عنصر 
من الجدول التفصيلي .ع1 اأة†م0 وما العنصر الذي يقابله من الجدول الرئيسي €[ Master‏ 


لنرى الشروط تكتب مباشرة أتناء عملية التحديد . 


(نضغط التالي ونكمل بقية متطلبات المعالج llخ|اص Data Block Wizard‏ ( 


شرح مسط : 

لو قمنا بتحديد عنصر العلاقة الجديد ۸610١‏ (غالباً ينشئ بإسم إفتراضي يأخذ فيه إسم الجدولين) 

تم ضغطنا ۴4 لنرى أهم الخصائص سنجد أنها : 

# خاصية شرط الربط 10۸†¡ك"C0‏ "1هل : ومنها تستطيع التعديل على شرط الربط الذي قد أنشئ فيما 
4 اة ساك حذف السجلات Record Behavior‏ eteاeط‏ والتي تمتلك الثلاثة القيم الآتية : 


1. atedاNon_so‏ : (اللا عزل وهو الإفتراضي) 
ويعني أنه لن نستطيع الحذف من الجدول ال٣عأكة“‏ إلا بعد حذف كل ما يتعلق به في الجدول ال كاأأم » 


Isolated .2‏ : 1 1 
ويعني وجود عزل بين الجدول ال۲عاكة× والجدول ال كاأزقا06 بحيت يمكن الحذف من احد الجدولين دون تاثر 


الاخر»ء 


Cascading .3‏ : 
فإذا حذفنا سجل من الجدول الاعائة× فإنه سيحذف كل ما يتعلق بهذا السجل من الجدول الكانهام0 . 
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2. الطريقة اليدوية : 
حیث نقوم بإانشاء ۴0۲۳ تکون فيه ال ھأة٥‏ 


)0ا معتمدة على الجدول للا5۲ وليكن ال 
بشکل اة يحوي سجلاً وحیدآً» و Master Block: STL‏ 
كذلك إنشاء )عها8 ها0 معتمدة على Detail Block: |MARK Sglect..‏ 
الجدول MAR)‏ ولیکن بشکل اطا E A‏ 
C Isolated Vv a‏ 

(@ Nonrlsolated FC Prevent Masterless Operation 


تم نقوم بتحدید ال( ء٣‏ ٥آtھامR)‏ الموجود 
في شاشة (Object Navigator)Jl‏ والتابع ا Mark.Mark_Sec = Stu. Stu_Sec And‏ 
للجدول الرئيسي لآ8 ثم عاeaاC Mark Malt = Stu Sth‏ 
لتظهر الشاشة التالية : 


&@ Join Condition 


4 
حيث نشاهد فيها أن الجدول الرئيسي Object REF‏ ¢ 
ل1 محدد تلقائياً بسبب أننا قمنا بتحديد ھن 
العلاقة من خلاله » بينما تتم المطالبة Cancel Help‏ 


بإاختيار الجدول التفصيلي من خلال الزر 
Sect...‏ لنختار من 10۷ التي تظهر 
الجدول MARK‏ ؛ ولنلاحظ سلوك حذف السجلات من خلال sعet‌lاe‌D Master‏ حيث نجد التثلات الخيارات : 


« Non_Isolated (a 

« Isolated (b 

„, Cascading (€ 

والتي تم شرحها في الفقرة السابقة ؛ 


ونكتب شروط الربط في ¬°٠ټditiİ" zel  JOİNn CO0‏ 
والتي قد قمنا بذكرها قبل ذلك . 


: Relation öةقاlلعل|‎ 


1. يضاف ۵۲ووا١‏ علی مستوی ال ۴۵0۲۳ 


2. يضاف (6۲5ووا۲ 2 ) علی مستوی 
كتلة البيانات )ها8 ها0 للجدول 
إلرئيسي Ns‏ . 

3. تضاف علاقة ١٥اأةاعR‏ إلى كتلة 
البيانات 

. Maئsأ€ع للجدول الرئيسي‎ Data Block 


. Program Units جمliربll إلى وحدات‎ ( 3 Procedure ) يضاف‎ .4 


LT 


حاضرات فی اوراکل دىفلویر 61 ORACLE‏ 
ك ملاحظة هامة : 
لا ننسى إخفاء حقول الربط بين الجدولين ( وذلك لعدم مواحهة مشكلة تكرار البيانات) وذلك من خلال 


إعطاء القيمة اال للخاصية C۸۷3١‏ لكل عنصر ربط ولتخفي العناصر أثناء التصميم والتنفيذ » أما إذا قمنا 
باعطاء القيمة ۸٠‏ للخاصية هاطأءا۷ فإنها ستخفي العناصر أثناء التنفيذ فقط . 


PIES boa SAS BSuaX #3 


سج7 


وهي هنا حقول : 


1. رقم القسم Se_N0‏ » 
2. رقم المستوی ٥۸_ا۷ا‏ ء 
3. رقم الطالب S†u_ N0‏ » 
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المحقول الحسابية: 
تكون الحقول الحسابية عادة عن طريق 


) عنصر 8۳[ غير مرتبط بقاعدة البیانات 08 _۸.0۸ على )ءها8ةtاة0‏ مرتبط بقاعدة البيانات 08 » 
) عنصر 18۳ غير مرتبط بقاعدة البیانات 08 _۸.0۸ على )z‌ها8‏ 2ا2 غير مرتبط بقاعدة البیانات N07_08‏ 
والذي عادة ما یسمی بال(yہصںد0)‏ . 


3. حقول الصيغة Formula‏ : 


مثال) مطلوب إنشاء عنصر يحوي مجموع درجات الطلاب (أعمال السنة والنصفي والنهائي)في كتلة البيانات Na)‏ ؟ 


ننشئ عنصر غير مرتبط بقاعدة البیانات‌۱0۸_08 وليكن ۲٥069‏ على جدول الدرحات 13۲۸ بالخصائص الآتية 


Property Value 
TDeg 
Text Item 
No 
Number 
Formula 
NVL(:Mark_Yj , 0) + NVL(:Mark_Ht , 0) + NVL(:Mark_Ft , 0) 
No 
CanvasZz 
الدرجحة النهائية‎ 


4. حقول التجميع Sum” ٣2٣۷‏ : 
مثال) مطلوب إيجاد متوسط درجات الطلاب النهائية ؟ (بالإرتباط مع المثال السابق) 


ه. نقوم بإنشاء )0ا8 غير مرتبط بقاعدة البيانات "٥١_08‏ وليكن (وصصں0) بالخصائص الآتية : 
Property Value‏ 
Name | Dummy‏ 1 


2 Database Data Block No 


۵. ثم ننشئ عنصر غير مرتبط بقاعدة البيانات08_١۸0‏ وليكن اه٤ه‏ بالخصائص الآتية : 
Property Value‏ 
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_ Summarized Block | Stu 

7 Summarized Item | 

_8 Summary Function | 

9 Database Item | 

__10 Canvas |... Canvas2 | 
11 Prom | متوسط الدرجات‎ 


.٤‏ وليتم التنفيذ بتجنب أي رسالة خطأً 
نقوم بتغير قيمة الخاصية Cc0rdعRe Mark تٽlجردلlب (Block)JJ ةعبlتll Query All‏ « 


ومن ال()عها8) التحكمي الذي يحوي عنصر التجميع۷ 01۳١۳‏ نغير قيمة الخاصية R0۲٩‏ eاSing‏ , 


Data Block Property Value 
_1| Mak Query All Record _____Yes| 
2 Dummy Single Record Yes 
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إيجاد ال لتقدير : 
ه) نقوم بإنشاء عنصر في كتلة البيانات )1۸۴۸ خصائصه كالتالي : 


Property Value 

__1 Name VALUATION 
2 Database Item No 
3| Canvas Canvas2 

4 Prompt التقدير‎ 
5 Prompt Justification Center 
__6___ Prompt Attachment Edge Top 
7 Prompt Alignment Center 


ط) ويما أن التقدير يعتمد على معدل الدرحات لذلك يجب أن يتأثر هذا التقدير إذا قمنا بتعديل أي من 
الدرجات لذلك نقوم بكتابة هذه الشفرة المصدرية 0de‏ في حدث e¢و۸ھاC€_Post‏ ولکل من ( اعمال 
السنة - النصغيى - النهائي) وكالتالي : 


Declare 


N Number; 


Begin 


N := NVL(:Mark Yj , 0) + NVL(:Mark Ht , 0) + NVL(:Mark Ft , 0); 


If N Between 90 And 100 Then 


:Mark Valuation := '‏ مناز" 


Elsif N Between 80 And 89 Then 


:Mark Valuation := '‏ جيدجد ام 


Elsif N Between 70 And 79 Then 


:Mark Valuation := '‏ جيدم 


Elsif N Between 50 And 69 Then 


:Mark Valuation :=‏ مقيول' 


glyatamiOnoiai N 
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' ضعيفء‎ :Mark Valuation := 


End ; 


لاع اص mmm‏ 
ا2ا يجراء تعرير استعلام تطمة مجل حتق نانذة تطضمات 3 
SQ aa CA Bax FF G3AQ‏ ? 
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8 ربط الجداول : 

نحتاج في كثير من الأحيان الربط بين جدولين ليس بشكل كاأةا06 & #۲أءة" وإنما بشكل ربط طبيعي من 
أجل إستخلاص معلومات معينة فمتلاً جدول الطلاب 5۲۷1 يحتوي على (رقم القسم ٤u_56ا†5)‏ والذي يعتبر 
حقلاً ممثلاً لمفتاح غریب ¥ ۸ و٥۲٥۴‏ تابع لجدول الأقسام ۸ S٤۲10‏ وعن طريق عملية الربط هذه نريد 
جلب أسماء الأقسام أي أننا نريد إظهار أسماء الأقسام في كتلة البيانات لا51 من خلال حقل رقم القسم 
عu_SاSt‏ وبشرط أنه إذا تم إدخال قيمة خاطئة فإن البرنامج يتوقف حتى يدخل المستخدم القيمة الصحيحة . 


رقم الطالب  _‏ إسم > رقم المستوى 


ذلك سنحتاج | 

: ه. إنشاء عنصر في كتلة البيانات ل51 خصائصه كالتالي‎ 
Property Value 
1| Name SEC_NAME 
2ِ Database Item No 
3| Canvas CanvasZ 
4 Prompt إسم القسم‎ 
2| Prompt Justification Center 
__6____ Prompt Attachment Edge Top 
Prompt Alignment Center 


ط. ربط هذا العنصر (إسم القسم) من خلال الحدث بعد التعديل 9#و٣هC1_اءه۴‏ التابع لرقم القسم الخاص 
بكتلة البيانات ل51۷ أي الحقل 6۲۷_5۴٩‏ وكالتالي : 


Declare 


Begin 
Select Sec Name Into :Sec_ Name From Section 


Where Sec No = :Stu Sec; 


Exception 
hen No 1 1 100 
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')Messageالرقم‏ غير صحيح;(' 


Raise Form Trigger Failure; 


End ; 


وبنفس الطريقة يتم إيجاد إسم المستوى المعتمد على رقم المستوى ... إلخ . 


تلمىح : 
من الممكن إنشاء رسالة 6۲ا۸ بدلا من رسالة #وهءءه" ولتكن خصائصها كالتالي : 


Property Value 

Name 
Title 

[ Message | 
4 Alert Style 

5 Button 1 Label 1 
6 Default Alert Button Button1 

ثم بعد ذلك نقوم بإستدعاء الرسالة أثناء معالجة الأخطاء ١٣هام‏ معء×ع وكالتالي : 


ا دما دں 


N := Show Alert ('Msgbox') ;‏ 
وذلك بعد تعركف المتحول في جزء داعم وكالتالي : 
N Number ;‏ 


من أجل أن الأوراكل تتطلب إسناد الدوال لمتحول أثناء إستدعائها . 
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يفضل دوماً التحكم بكتلة بیانات 08 عن طريق عناصر 0١_08‏ بحيث تكون آتية من كتلة بيانات N0۸_08‏ 
والتي ما نرمز لها عادة بالرمز "١1ا0‏ أي كتلة تحكم » وفي مثال ربط الجداول السابق فإنه يفضل أن ننشئ 
عنصر إسم القسم S۴٤_۸N2۳۴‏ في كتلة بيانات "0١_08‏ ولتكن ¥" "01۳ والذي من خصائصه : 


Property Value 

Database Data Block No 
ع1_اءأا (راجع كيف تنشئ القائمة‎ "١_5٥٤ وإذا أنشئنا إسم القسم هذا من نوع 18۳ اكا وليكن إسمه‎ 
من المحاضرة السابعة) وأردنا أن تكون البيانات المعروضة فيه تؤثر على ما يعرض في كتلة البيانات ل1؟‎ 
: بشكل فعال فإننا نقوم بكتابة الشفرة المصدرية في حدث (تعديل القائمة) وكالتالي‎ 


(Trigger : WHEN_LIST_CHANGED) 


Set_ Block Property ('Stu'" j 'Default_Where'" "Stu Sec = 
:Dummy.List_ Item Sec') ; 


ومن أجل ألا نختار عنصر من القائمة ٣٤٤1(۳_S_اءأا‏ ثم نضطر إلى الذهاب إلى كتلة البيانات لا51 لتنفيذ 
الإستعلام أي نجعل ظهور البيانات في كتلة البيانات لا51 مرتبطاً بإختيار القيمة من ٣٤٤؟_‏ 8۳ ا1_اءأا فنضيف 
في حدث (تعديل القائمة) بعد التعليمة السابقة ما يلي : 


Go Block (SEU) F 


Execute_ Query ; 


*٭* الوحدات البرnمج Program Units‏ : 3 
ا ای ا سے و ی ا 

تستخدم الوحدات البرمجية لإنشاء الإجراءات ۲٠‏ ع١۴۲‏ أو الدوال 

Function‏ أو الحزم البرمجية م5 عوه)ع۴a‏ » وذلك من خلال اا 

بتحديد ال(ئitہ U‏ صamاوداP)‏ الموجود في شاشة ال( اءObje‏ أ e‏ 

: تم عatعاC لتظهر الشاشة التالية‎ )Navigator 


@ Procedure 
C Function 


f Package Spec 


فنكتب إسم الوحدة البرمجية المراد إنشائها داخل ال (عمصج١) EI‏ 
تم نختار نوع الوحدة البرمجية هل هي : Type Spec‏ ¢ 
Type Body‏ ^ 
Procedure cly)z<| °‏ « 
Cancel | __ Hew | « Function alls °‏ _ 
ه٠‏ حزمة برمجية عءعمS‏ مءوهa)عم۴‏ » (نحدد فيها أسماء 
الوحدات البرمجية) 


حسم lانحjمة Package Body‏ « 
الت يتم فيه كتابة الشفرة المصدرية عل٥)‏ للإجراءات والدوال التي تم تجميعها في ٤€مS (Package‏ . 
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ه) مطلوب إنشاء عنصر في كتلة البيانات 21۲K‏ يعرض مجموع درجات الطلاب (أعمال السنة والنصفي والنهائي) ؟ 
(بإاستخدام الإجر|ءlت (Procedure‏ 
ط) مطلوب إنشاء عنصر في كتلة البيانات ا5 يعرض إسم القسم ؟ (بإاستخدام الدوال (Function‏ 


أولآً) ننشئ عنصر غير مرتبط بقاعدة البيانات08_١0١‏ وليكن و٠192‏ بالخصائص الآتية : 


Property Value 

_1 Name | Deg 
2 Item Type | 
_3 Enabled | 
_4 Data Type | 
_5 Database Item | 
6 Canvas | 

محموع الدرجات | Prompt‏ 7 


تانىاً) نحدد ال(ءئit‏ لا صramاودا۴)‏ الموجود في شاشة ال( 0۲ځNaviga‏ ectز0b)‏ ثم Create‏ لتظهر شاشة 
الوحدات البرمجية فنكتب في ال هه" إسم الإجراء وليكن وم٥٥ ۴۲١١‏ ونختار نوع الوحدة البرمجية إجراء 
cedureداP‏ تم نضغط )© . فيظهر محرر كتابة الشفرة المصدرية لنكتب التالي : 


PROCEDURE ProTDeg IS 
BEGIN 

:Tdeg := NVL(:Mark Yj , 0) + NVL(:Mark Ht , 0) + NVL(:Mark Ft , 0); 
END; 


ثالاً) ويما أن المجموع يتأثر إذا قمنا بتعديل أي من الدرحات لذلك نقوم بإستدعاء الإجراء عإduعع0ا۴‏ من 
خلال كتابة هذه الشفرة المصدرية ع٥ل0)‏ في حدث عمو ,هةط€_غP۴os‏ ولكل من (أعمال السنة - النصفي 
- النهائي) وكالتالي : 


ProTDeg ; 


حاضرات فی اُوراکل دىفلویر أ6 ORACLE‏ 


Property Value 

1| Name SEC_NAME 
2 Item Type Text Item 
3| Enabled No 
4| Data Type Char 
5 Database Item No 
6 Canvas Canvas2Z 

إسم القسم Prompt‏ 7 


تانىاً) نحدد ال(ءUnit‏ صramاودا۴)‏ الموجود في شاشة ال( a0وNaviİ‏ ectز0b)‏ تم عatعاC‏ لتظهر شاشة 
الوحدات البرمجية فنكتب في ال ع6"ه4. إسم الإجراء وليكن € ۸86€ ا۴ ونختار نوع الوحدة البرمجية إجراء 
Function‏ تم نضغط 0۸ . فيظهر محرر كتابة الشفرة المصدرية لنكتب التالي : 


FUNCTION FunSec RETURN Char IS 
X Varchar2 (50); 
BEGIN 
Select Sec Name Into X From Section 


Where Sec No = :Stu Sec ; 


Return X ; 
END; 


ثالثأً) ثم نقوم بإستدعاء الدالة ١٥نا٤‏ ٣ا۴‏ من خلال كتابة هذه الشفرة المصدرية ٩)0‏ في حدث بداية 
الدخول على السجل وكالتالي : 


(Trigger : WHEN_NEW_RECORD_INSTANCE) 


:Sec_ Name := FunSec ; 


ملاحظات هامة : 

٠‏ يمكن إستدعاء الإجراء بكتابته مباشرة » أما الدالة فيجب أن تسند لمتحول أثناء إستدعائها لأنه من 
الممكن أن يستخدم إسم الدالة مع العمليات الحسابية › 

٠‏ لا يتطلب من الإجراء إرحاع أي قيمة بينما يجب أن تعيد الدالة قيمة لذلك فإنه عند تحرير الشفرة 
المصدرية للدوال سنرى بداية محرر الشفرة المصدرية بهذه الطريقة : 

FUNCTION FunSec RETURN _ IS 


فنقوم بكتابة ما ترجعه الدالة بحيث نعدل محرر الشفرة المصدرية وبهذه الطريقة : 


FUNCTION FunSec RETURN Char IS 


OT 


1 Cancel | Help | 


حاضرات فی اوراکل دىفلویر آ6 ORACLE‏ 


# إنشاءعتنصر 0 ع|)| 1it‏ : 
قبل إنشاء 18۳ انا يجب معرفة هل نريد أن تكون القيم الظاهرة فيها : 


٠‏ تابتة (إستاتيكية) ها6 : وبالتالي فهي تمتلك قيم ثابتة لا يمكن تعديلمها ؛ 

٠‏ متغيرة (ديناميكية) ¥١3 ۸١١1٤٥‏ : وبالتالي فهي تمتلك قيم متفغفيرة تعكس صورة السجلات في قاعدة 
البيانات وجلب البيانات فيها سيكون بواسطة الإستعلام ۴۲۷ا . 

مع ملاحظة أن إنشاء ال(٣٠۴ا!‏ اكأا) يكون يدوي دائماً . 


أمثلة ذلك : 
مطلوب عمل 1٠٣١‏ ء11 في الكتلة الخاصة بالجدول 5u‏ بحيث يكون : 


حقل رقم المستوى مرتبطاً مع حقل إسم المستوى (يعرض بيانات ثابتة) › 
) حقل رقم القسم مرتبطاً مع حقل إسم القسم (يعرض بيانات متغيرة) ؟ 


بعد إنشاء ۴١۲۳‏ تكون فيه ال۸عها8 aاة0‏ معتمدة على الجدول ااك نلاحظ توفر الحقول : 


( رقم الطالب ٥١۸_نا؟‏ . إسم الطالب ع٠۳ة١_uاS‏ . رقم القسم ٤u_5€ااS‏ . رقم المستوى ا۷ا_نااS‏ . المعدل 
Stu_Certtype öةدlشll عgi « Stu_Avg‏ ( 


مما يستوجب توفير حقل إسم المستوى وذلك من خلال إنشاء عنصر جديد 8۳ا1 خصائصه كما يلي : 


Wl List Elements 


Property Value List Elements 
1 Name LVL_NAME : 


4 Mapping of Other Values 4 


7 Synchronize with Item STU_LVL List tem Value 


1 


9 Canvas Canvas2 
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 qlyatawiOnotmail et) 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


EEE ۳ “1‏ ت 
?2Icsietl » >» 4 aI HOS BOX] AQ‏ 
اهر الشاشة أعلاة والتي مى خلا : ا 
٠‏ ندخل قيم الحقل 1۷1_2۳8 في mz‏ 
List Elements‏ کے 


ه٠‏ نحدد القيم المقابلة لها في حقل رقم اا 
nllسwت“ک List Item Values‏ « 2 

مع وجوب أن يكون إدخال القيم متناظر في 

جميع الأعمدة (الحقول) فمتلاً : 


القيمة الأول في ٣٥۶‏ ٥|اع‏ اءذا يقابلها 


e . List Item Values القيمة 1 في‎ 

کے شرح مسط : 

٠‏ لاحظ عمل خاصية نسخ القيمة للعنصر إلى داخل قاعدة llبيlilت Copy Value from Item‏ )إلى 
(STU_LVL‏ 


وذلك مغيد حدآ عند إضافة سجل حديد (غالباً ما يتم إخفاء حقل ا۷1ا_ل51۷ بواسطة الخاصية °3۸۷35 
والإعتماد على 1۷1_۸۷٤‏ كمدخلات معطاة من المستخدم وهنا تأتي الفائدة العظمى لهذه الخاصية) › 

ه٠‏ لاحظ عمل خاصية التزامن مع العنصر "1۵ wit‏ مizرمoاhعnصرك‏ والتي تعمل على إظهار قيم ال انا 
بعد ا على قيمة حقل رقم المستوى 5_۷ (شبيهة في طريقة العمل ل : (Trigger‏ 
Post_Change)‏ 


على حقل )S۲۷_1۷1‏ > 
٠‏ لاحظ أن "1(۳ اكا شبيهة في طريقة العمل للدالة مأهعه2 في بيئة 15ا۲ 5Q)‏ . 


LT 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


أولاً ) توفير حقل إسم القسم وذلك من خلال إنشاء عنصر جديد 16۳ خصائصه كما يلي : 


lw List Elements × 
Property Value List Elements 
ا‎ I1___Name LVL NAME, 
2 Item Type List Item ا‎ 
ا‎ 
ii | 
د‎ n ا ا1ا‎ 
List Item Yalue 
1 Cancel Help 


: لاحظ كيف فمنا بتفريغ كل من‎ 
« Element In List ja جميع القيم‎ (a 
. Mapping of Other Values & Initial Value „Jiuصlخ‎ (b 


ثانياً) ننشئ مجموعة سجل طلا٥6۲ R٥٤0١۲١4‏ متغيرة (ديناميكية) 0۷۸3۳۸1٤٥‏ حيث نقوم بتحدید ال( Re c0۲٩۵‏ 
0upاG)‏ الموجود في شاشة ال(0۲ةوNavi‏ ctعز0b)‏ تم عatعاC‏ لتظهر الشاشة التالية فنختار خيار ased۾6‏ 
n the Query Below...‏ ونکتب الإستعلام تم نضغط على الزر )0 


select Sec Name , to_char (Sec No) from section ; 


إذن نقوم بجلب البيانات الخاصة بإاسم × 
القسم ورقم القسم (بعد تحویله من رقم Data in this Record Group will be:‏ 
إلى نص عبر الدالة to_char()‏ وذلك لیکون C Static Walues‏ 


(@ Based on the Query below... 


مجموعة سجل Re٤۵۲۵ 6۲۵۷p‏ قادرا علی 
الإستعلام) » ويجب أيضأاً أن نجعل نوع 
البيانات لرقم القسم C۸3١‏ ولتتم عملية 


Query Text: 
SELECT SEC_NAME , TO_CHAR(SEC_NO}] FROM SECTION 


› التطابق‎ 
= Property Value 
Data Type Char 
OK Cancel Hel 
E EE E cm برمجیاً‎ )Rعc0٣d‎ Grup ولنسمي هذا ال(‎ 


من خلال الضغط على ۴4 وتحديد قيمة 
llلخlاصيıةö Name‏ ڊ RG_SEC_DYNAMIC‏ 


النموذج ع 


من ۳ ۴)] ااا و ع ال ص قوم بكتابة ال المصدرية 
فاعدة البيانات : 
(Trigger : N‏ 


ORACLE 


حاضرات فی اوراکل دىفلویر أ6 


_SEC_DYNAMIC'); 


Sec_Name','RG_ SEC DYNAMIC'); 


لداعل 
ا ا2ا لجراء دير اتمم اتضة مجل حق ناندة يات 
SCC B>» aa SA BShaX FF G3Q‏ ? 


إ 
أ 


1 


1 


| 
+ 


1 


f ff, Hkhke 


LOVs (List Of Values) القائمةالمركبة‎ * 


Populate Group ('RG_ SI 


Declare 


N Number; 


Begin 


N := 


Populate List ('" 


End ; 


* 
هي عبارة عن قائمة تحتوي مجموعة قيم نقوم بانتقاء إحداها وإعادتها إلى حقول في ال (Form)‏ > وتتمىز 


`“ ahawiChotnail 4 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


ع) إمكانية البحث ١ءa۲ع5‏ والتصفية (الفلترة) ۲عااأ۴ . 


: LOVs (List Of Values) siشij‎ %* 

قبل إنشاء قائمة مركبة 10۷6 يجب معرفة هل نريد أن تكون القيم الظاهرة فيها : 

ه٠‏ تابتة (إستاتيكية) ءأ٤ه6t‏ : ويالتالي فهي تمتلك قيم ثابتة لا يمكن تعديلها ؛ 

٠‏ متغيرة (ديناميكية) 0۷١3٣1٤‏ : وبالتالي فهي تمتلك قيم متغيرة تعكس صورة السجلات في قاعدة 
البيانات وجلب البيانات فيها سيكون بواسطة الإستعلام ا٥د‏ . 

مع ملاحظة أن ال(ئ10۷) لا تطبق عادة إلا على عنصر "۳ء (! ٦6×‏ » 


وإنشائها إما أن يكون يدوياً أو عن طريق المعالج الخاص ڊlş Form Builder 6i ) ııı>] LOVs Wizard‏ ([ . 


وبشكل عام فإن إنشاء أي ء10۷ يتطلب |iشlء‏ مجnمaعZعة‏ wجJ Record Group‏ 


وبحسب نوع مجموعة سجل upهاG R0۲۵‏ بتحدد نوع ال ئ10۷ 


أمثلة ذلك : 
مطلوب عمل 10۷s‏ في الكتلة الخاصة بالجدول اه" بحيث يكون : 


› Nau 11y حقل رقم المستوى مرتبطاً مع حقل إسم المستوى (يعرض بيانات ثابتة) بإستخدام الطريقة اليدوية‎ )٤ 
حقل رقم القسم مرتبطاً مع حقل إسم القسم (يعرض بيانات متغيرة) بإستخدام المعالج إW¡z21 ؟‎ )٩ 


بعد إنشاء ۴١۲۳‏ تكون فيه ال)عها8 aاة0‏ معتمدة على الجدول M131۸‏ نلاحظ توفر الحقول : 
( رقم القسم ٤K_5€ا Ma‏ . رقم المستوé” Mark_Lv|‏ . رم |ÛÙJطJlلئب Mark_Sub öدامJl مêر . Mark_Stu‏ « 
أعمال السنة ز۲۸_۷ة× . النصفي ١_)۲ةM‏ . النهائي اM2۲)_۴‏ ) مما يستوجب : 


أولاً ) توفير حقل إسم المستوى وذلك من خلال إنشاء عنصر جديد 18۳ خصائصه كما يلي : 


Property Value 
Name Lvl_Name 


Record )JI 
Static رlıخ‎ 
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| wî MOL wi MODULE1: Column Specific lion × 


× 


Caneel | He 


حاضرات نی اوراکل دىفلویر أ6 ORACLE‏ 


( ندخل إسم الحقل 1۷1_N0‏ في Column Names‏ ونحدد نوعه Number‏ في ype‏ هغهد آما طوله 
thوLen‏ فهو محدد تلقائياً للأرقام ومن ثم ندخل جميع القيم الممكنة لهذا الحقل |1,2,3,4[ Column‏ 
Values‏ ( « 


ونكرر ذلك مع حقل إسم المستوى حيث : 


( ندخل إسم الحقل ٤L۷1_NAMا‏ في Names‏ nصumاo€‏ ونحدد نوعه r2۲عtع‌Ch‏ في ۲ye‏ ھtaغa‏ 2 وطوله 
thوLenا‏ هو 30 ومن ثم ندخل جميع القيم الممكنة لهذا الحقل [ الرابع ,الثالث ,الثاني ,الأول] ”صuامCع‏ 


ئا ) » مع وجوب أن یکون إدخال × 
القيم متناظر في جمیع الأعمدة (الحقول) Data in this Record Group will be:‏ 
فمتلاً القيمة 1 في رقم المستوى يقابلها SEV‏ 2 

f” Based on the Query below... e | فة الأول في إسم‎ | 
E 2 برمجیاً‎ )R0۲۵ 6۲٥p ولنسمي هذا ال(‎ 


من خلال الضغط على ۴4 وتحديد قيمة 
ائلخlاصيةö RG_LVL_STATIK Name‏ 


= 
cea | ee | 


Data Type 


| Character ¥ [ 


تالغ ننشئ قائمة مركبة 10۷6S‏ معتمدة على نوع 
Record Group‏ السابق [تابتة (إستاتيكية) ٤أاة)؟]‏ حيث 
نقوم بتحديد ال(10۷5) الموجود في شاشة ال(اءع[5ا©0 


fair MATT Browse... | م۾î‎ (Navigator iwi LOY Column Mapping 
عا‎ I idth 5 ۴ ا‎ j ۲ t 
Gotumn Tite E Column Names 


EES ances aim 1‏ 
هل هي باستخدام ا 2 


المعالج أم يدوباً 
| فنختار (الخيار اليدوي) لااua a new L00۷ man‏ dاBui‏ . ولتكون الخصائص 
| لل فا كما يلي: 


Return Item 


MARK.MARK_LVL Browse... | 


Display Width 
50 


Column Title 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


Column Mapping Properties 


Automatic Skip 
: لتظهر الشاشة المجاورة والتي من خلالمها‎ 


( ندخل إسم الحقل 1۷1_N0‏ في Column Names‏ ونحدد إرجاعa‏ |l”ى Return MARK.MARK_LVLJ٢>‏ 
tem‏ عن طرق الزر ...8۲0۷58 وعرضه 50 أثناء عرض القيم في 10۷5 وعنوان هذا الحقل رقم المستوى 
leاi¡t٥ Column‏ ) . ونکرر ذلك مع حقل اسم المستوی حیث : 


( ندخل إسم llحaقJ L1V/1_NAME‏ في Column Names‏ ونحدد إرجاعه MARK.LVL_NAME Jتح JJ|‏ 
Return Item‏ عن طرق الزر ...8۲0۷56 وعرضه 100 أثناء عرض القيم في 10۷5 وعنوان هذا الحقل إسم 
nJlستiو“ Column Title‏ ( . 


رابعاً ) بعد تصميم ال10۷5 نحدد ظهورها على حقل رقم المستوى ۷1ا1 MARK_‏ وكما بلي : 


Property Value 

List of Values LOV_LVL_STATIC 
(ga EGE 
2? SG Daa OS BPX FF AQ 


رد ققح ا ات رت مو وی رق مقت رت فاو اتی ٣‏ 
١‏ اکسیرتر 1 


فت 
TT‏ 


حل المطلوب الثاني 
أولاً ) توفير حقل إسم القسم وذلك من خلال إنشاء عنصر جديد 6۳ا[ خصائصه كما يلي : 


Property 
Name 


ا 
ا 


Canvas 


| 
ج 


(Trigger : Post 


: وكالتالي‎ Nd Sec 
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ڪ 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


Declare 


Begin 
Select Sec Name Into :Sec_ Name From Section 


Where Sec No = :Mark Sec; 


Exception 
When No_Data_Found Then 
الرقم غير صحيح;('‎ Message)" 


Raise Form Trigger Failure; 


End ; 


ثالةاً) ننشئ مجموعة سجل upاهإ6 ۸٥٤0۲١‏ متغيرة (ديناميكية) 0۷۸3۳1٤‏ حيث نقوم بتحديد ال(0۲۵ءعR‏ 
0upاG)‏ الموجود في شاشة ال(Naviga0۲‏ ctعز0b)‏ تم عatعاC‏ لتظهر الشاشة التالية فنختار خيار ased۾6‏ 
n the Query Below...‏ ونکتب الإستعلام تم نضغط علی الزر )0 


select Sec Name , to_char (Sec _ No) from section ; 


إذن نقوم بجلب البيانات الخاصة بإاسم ا× 
القسم ورقم القسم (بعد تحویله من رقم Data in this Record Group will be:‏ 
إلى نص عبر الدالة to_char()‏ وذلك لیکون C Static Values‏ 


(&@ Based on the Query below... 


مجموعة سجل Re٤۵۲۵4 6۲۵۷p‏ قادرا علی 
الإستعلام) » ويجب أيضأاً أن نجعل نوع 
البيانات لرقم القسم ۸3١‏ ولتتم عملية 


Query Text: 
SELECT SEC_NAME , TO_CHAR(SEC_NO}] FROM SECTION 


» التطابق‎ 
= Property Value 
Data Type Char 
OK Cancel Hel 
E e برمجیاً‎ )۸8C0۲۵ 6۲۵p ولنسمي هذا ال(‎ 


من خلال الضغط على ۴4 وتحديد قيمة 
llخlاصيıة Name‏ ڊ RG_SEC_DYNAMIC‏ 


ثالقآ) ننشئ قائمة مركبة Sئ10۷‏ معتمدة على نوع مدهإ ه١إمعه۸‏ السابق [متغيرة (ديناميكية) 0۷12۳1٤‏ ] 
حيث نقوم بتحديد ال(كئ10۷) الموجود في شاشة )Object Navigator)J|‏ تم 
Create‏ لتظهر شاشهتوتحديد طريقة الإنشاء بوا ستخدام المعيج أم × 


QWICNOMAL EAN 


li MODULE1: New ListOfValies (LO 


Cieate a new List-Of Values (LOY) 
( Use the 


LOY Wizard 
( Build a new LOV manually 


Cancel Help 


ORACLE حاضرات فی اُوراکل دىفلویر آ6‎ 
« Use the LOV Wizard 


لتظهر الشاشة الأولى في معالج 10۷5 والتي تقوم بالسؤال عن توفر إحدى متطاباتها وهو مجموعة سجل 
Record Group‏ فمل : 


› تريد إنشاء مجموعة سجل جديدة تعتمد على الإستعلام‎ ٠ 
. يوحد مجموعة سجل منشئة مسبقاً‎ e 
تم نضغط‎ . R6_SEC_DYNAM1]C٥ (حالياً سنختار الخيار الثاني [المنشئنة مسبقاآ ] ومنها بالتحديد‎ 


التالي) 3 
قد تتساءل لماذا لم نجد الشاشة الترحيبية كما هي العادة في LR E‏ 
Wizards a‏ والسبب قوي ذلك یعود إلى عدم تنشيطها فإذا Deyo iar io başê vo LOY cn a pev Record Group.‏ 
أردت ذلك فقم بالخطوات التالية (من خلال قائمة الأدوات) : Recs Bue seu et el Ê‏ 
queıy.‏ 

2 Tools > Preference... > Wizard > 

New Record Group based on a query 
@ Eisling Recaıd Group REET] VM LOV Wizard Welcome Page 
: ثم تظهر شاشة تخبرك بأنك هل‎ 

| تمي _[ ست ]| ساق 


« Record GrOUPpةiشنiمnلll‎ Jجس تريد التعديل على مجموعة‎ ٠ 


. تريد إنشاء مجموعة سجل جديدة‎ ٠ 
(حالياً سنختار الخيار الأول ثم نضغط التالي)‎ 


لتظهر بعدها شاشة تأكيد مجموعة السجل ا6۲0 ۸8٤۳0۲١‏ حيث يمكنك تحريرها مباشرة في 5Q) Q6۷‏ 
Statement‏ أو بناءها من جدید من خلال برنامج باني الإستعلام Q8۲...‏ ا50 اا8 أو إستيرادها من ملف 
[port SQا Query...‏ وهناك أيضاً زر الإتصال إن لم تكن متصلاً بالقاعدة ...أ) ٥0١٣۴‏ و زر فحص الصيفة التي 


LOV Wizard × LOV Wizard x 


The LÛY you are crealing/modiying is galling ils dala 
from a Record Group based on ã SQL quay 

If you make any changes in the LOY wizard that would 
cause lhe Record Group to be modfied, do you want 


your changes to ba applied to the evisling Record Group 
ol cteala a new Recoced Group? 


Record Groups canı be based on SQL queries. Oo you 
wanî to enter oe modify lhe quay that your LOVs Recotd 
Group uses? 


If š0, you may use the Oracle Developer Quesy Builder 


by clicking Build SQL Query, Of, you fay erte yout 
query Greclly into the SOL Query Statemert fiekd below. 


Import SQL Queey... | 


SQL Queey Statement 


SELECT SEC_NAME , TO_CHARISEC_NO] FROM 
SECTION 


Gonnect.. | Check Synlan... |‏ 
| تما | دته | سبو aie‏ | نميه _[ داتت | اسب | تطيمك _|_ إلغاء 


@ Hoi, essing Record rour] 


(f Gıeale new Record Group 


1ya ORO ۰‏ ل 


tzard 


LOY 
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بعدها تظهر شاشة لتختار الحقول التي جلبتها من إستعلام محموعة سجل م6۲0۷ ۸۴٤0۲4‏ وما الذي تريد 
جلبه وإظهاره على القائمة المركبة 10۷6 (حالياً سنختار حلب الكل الزر << ثم نضغط التالي) 


ثم تظهر أهم شاشة من شاشات المعالج وهي شاشة تحديد العناوين الظاهرة للحقول في القائمة المركبة 
عاİtآ‏ والحجم الخاص بالعرض W1٣١‏ والأهم ربط الحقول التي جلبت بالإستعلام وإرحاعها للحقول المراد 
إرجاع llبlıنات‏ |ılڳlْ SEC_NAME  Elرlب pgãaiw ÎıJl<) Lock Up Return Item...‏ إل 
MARK.SEC_NAME‏ & الحقل 0 MARK.MARkK_SEC JلJإ 1٥C۸6G6Q_‏ ثم نضغط التالی) 


LOV Wizard × 


[LOV Wizand × 
[ems and Puametett | × 


‘Your LOY may inchuda some ot al of lhe cokımns in he 
Record Group. Which Record Group cokurens do you 
wish to include in your LOV? 


I you wish lo specily fhe LOV cokmın propefies, you 
may erlet a ie, widh and ıehum vake foe each LOV 
coknn. The units for the cohen width is Points 


Record Group Columns LOY Columns 


لتظهر بعد ذلك شاشة نحدد من خلالها العنوان العام للقائمة المركبة عا" وكذلك عرض القائمة 1ال 
وإرتفاعها واه وتحديد ما إذا كنت تريد إظهار القائمة المركبة في إحداثيات أتوماتيكية أو تقوم بتحديد 
الإحداثيات يدوياً , (حالياً سنعطي العنوان 

أرقام الأقسام مع أسمائها ثم نضغط 


LOY Wizard لتا لی) الک‎ | 
What tille would you Eke to display in your LOY window? 
1 تم تظهر شاشة لتحديد إمكانيات : ارقم اإقساء مع اسماتما]‎ 
E Te e E › عدد الصفوف الظاهرة‎ ٠ 
Wan [240 Heg (5 | إمكانية تحديث البيانات قبل عرضها في‎ ٠ 
Do you wart Fcems Rurfime to poshion your LOV? « LOVS 
€ Yes. let Forms postion my LOV automatically إمكانية الفلترة للمستخدم عند بداية‎ ٠ 
(` No,I want to poston * marsıaly . LOVS 
E E (حاليا نضغط التالي)‎ 
ا‎ EE لتظهر شاشة التأكيد على حقول الإرحاع‎ 


(حالياً سنختار حلب الكل الزر << تم نضغط التالي) 


فينتهي بذلك معالج القائمة المركبة (نضغط نهاية) 


LT 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


LOV Wizard 3 × LOV Wizard × 


You aie returning values ftom your LOV to the following 
Rems. You may assign your LOY to some o¢ all of hase 
hems. 


Do you wani to modify the advanced peopeıties that 
affect the behavior of you LOY? 


If you are not famiias with thei usage, it is recommended 


thal you accept the defaults as hey appear below. To which of these hems do you wish to assign your 


Return Items 


Retieve 2 rows al a me, 
IF Refresh record group gata befote displaying LOV 
FT Let the user filter records before displaying them 


LOV Wizard × ي ا‎ rar TI OES Es ase ° parr 
? STG Baa ag PD>X< FF oQa 


To create the new LOV and any associated Recotd 
Group, cick Finish. Tha Object Navigator wil display anı 
eniry for your newe LOY. 


To modify lhe LOY in the future, you can recall ha LOV 
\Wizaed. To do so. select the LOV in Ihe Navigstoc. and 
choose LOY yizatd ftoen the Tools Menu. 


رت تي حقحة ١‏ 
7 


س [ سه ]|__| سب 
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ولنسمي هذا ال( ك10۷) برمجياً من خلال الضغط على ۴4 وتحديد قيمة الخاصية ع٣2١‏ 
LOV_LVL_STATIC,‏ . 


نلاحظ أنه قد تم من خلال المعالج ما بلى : 


للخاصية ١ا‏ القيمة أرقام الأقسام مع أسمائها في الئل۷ا10 › 

» L0۷كلا في‎ RG_SEC_DYNAMIC القيمة‎ Record GrOUPp للخاصية‎ 

للخاصية Mapping Properties‏ umnاco‏ في الك10۷ تم إرحاع القيم للحقول المعنية بذلك . 

« MARK_SECJ| „ê LOV_SEC_DYNAMIC aةanيقلl‎ List of Values إعطاء خاصية‎ ٠ 

وكذلك في ال٤۳_N۸۷٤S5‏ (ولتتجنب ظهور القائمة مرتين إجعل قيمة الخاصية في ال S۴٤_N۸۷N۴‏ تساوي 
(NULL‏ . 


: LOVs (List Of Values) صئiصخ من‎ 

1. الخاصية yھامءDi‏ eمeforط ۴te‏ : تستخدم عندما تكون السجلات كثيرة حيث تظهركئ۷ 0| عند 
التنفيذ جاهزة لإدخال جزء من قيم الحقل المراد إظهاره وذلك عند جعل الخاصيةكءY‏ . 

: Automatic Display ةيصlخJ|l‎ .2 

إذا جعلناها ك6 فإنه سيتم إظهار الئلا 10 مباشرة عند وصول المؤشر إلى الحقل M»۸R۸)۸_S٤۴٤٣‏ مثلاً وذلك 

ندون : 

» الضغط على ۴9 لإظهار القائمة المركبة‎ ٠ 


: كتابة شفرة مصدرية ۴ل0) كما في هذا المتال‎ ٠ 
(Trigger : WHEN_NEW_ITEM_INSTANCE) 


Declare 


J Boolean; 


Begin 


J := Show_Lov ('LOV_SEC_DYNAMIC'); 


End ; 


3. الخاصية )ك Automatic‏ : إذا كانت ١ء۲‏ فإن المؤشر ينتقل للحقل الذي بعد حقل الكا10 بعد 
الإختيار وإذا كانت ۸٥‏ يظل في نفس الحقل بعد الإختيار » (بالطبع الزمن عامل مهم في قواعد البيانات) . 


ك ملاحظات هامة : 


) يوجد تشابه بین ئ10۷ و۴۳٤1‏ غاا ولکن تتمیز الئلا 10 بوجود الخاصية ۴٣۵‏ 
والتي تسهل إيجاد قيمة معينة إذا كانت القيم كثيرة . 


) يفضل إستخدام ال٣ع٤!‏ tواا‏ إذا كانت القيم liبتةö Static Values‏ 


بينما يفضل إستخدام إلء10۷ إذا كانت الة 3 Dynamic Valu ö‏ . 
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اأحاضرة الشامنة 


% إiشuiaesliصmصر Radio Group & Radio Button‏ : 
من المعلوم أن عناصر الإختيار المفرد لا تكون إلا لقيم ثابتة مثل (الجنس » الحالة الإجتماعية ... إلخ) › 


وهذه العناصر يجب أن تجمعها حاوية i"8۲ه†٣٥٤‏ حتى يمكن إختيار خيار واحد من كل مجموعة وهنا في 
Oracle‏ 


قد تم وحب تصميم الحاوية ١۴8۲‏ اهاه أولاً ثم إنشاء العناصر التابعة لها أي أنه : 


يتم إنشاء u0pںاG‏ 0الهR‏ أولاً ثم العناصر lillبعة‏ لButtonsl Radio‏ 


ا مثال ذلك : 
× 


Tee | Te | 


مطلوب إضافة حقل الجنس (ذكر/أنشى) لجدول 
الطلاب ا5 ومن ثم عرض البيانات في نموذج 
Form‏ ؟ 


Enler a lable or view on which to base yout dala block. 
Then select le column that should appear as leme. 


Table or view. 
Bu Bowe | 

ولعمل ذلك لا بد أولاً من إضافة هذا الحقل = 
بأمر ا50 وكالتالي : 


SQL> alter Table Stu 
Add (Stu_ Sex number (1)); 


(إذا قمت بإنشاء الحقل بعد جلب البيانات 
إJJ Data Block J| ııدحتڊ pa FormJl‏ 
(511) ثم إنقر على زر الفأرة الأيمن لتختار 
ata Bloc) Wizard‏ ومنه التبویب 
عاabا‏ تم إضغط الزر إئمإ۴هR‏ وبعدها قم بجلب العنصر ×٤S؟_ل5110‏ ثم إضغط نهاية) 


أو نقوم بإنشاء ۴۵۲۳ تكون فيه ال)عها8 هاة0 معتمدة على الجدول ل51۷ لنلاحظ أن الحقل ×ع؟S_ل51۷‏ قد 
أخذ الشكل الإفتراضي للعناصر وهو 1(۳ ۲٠×‏ . ولجعله بشكل Radio Buttons‏ منتم إlأJى Radio Group‏ 
نقوم بتعديل قيم الخصائص التالية : 


Property Value 


1 Name STU_SEX 
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4 Initial Value 


حاضرات ي اوراکل دىقلویر آ6 
۰ 
نلاحظ بعد ذلك إختفاء الحقل من شاشة التصميم ٥‏ اا٤‏ اuمرها‏ لأنه قد تم تكوين upها6‏ i0لةR‏ » ولم 


یتکون آي عناصر إختيار ۸5 Radio But0‏ حتى الآن لذلك نقوم بتحدıد Radio Group (S1U_SEX) J|‏ ومن 
Radio Buttons‏ تم Create‏ لعنصرین خصائصهما کالآتي : 


=--[@§] STU_SEX 


a Property Value Property Value 
2 
@ MALE 
ا‎ 1 Name MALE 1 Name FEMALE 
e 7 ا‎ e MT E OIE ST ST | 


إذا لم يتم ظهور العنصرين فإذهب إلى خصائص R2Q0 6۲01p‏ وأعطي القيمة Ca ١۷252‏ للخاصية °C87۷85‏ » 
لنلاحظ بعدها تنفيذ البرنامج وظهور القيم على شكل إختيارات مفردة بدلا من القيم المدخلة كما في ×16 


. Item 


LT 
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من المعلوم أن عناصر الإختيار المتعدد لا تكون إلا لقيم ثابتة مثل ( الجنسية » الحالة الإحتماعية ... إلخ) > 


ومن الممكن إختيار أكثر من خيار واحد . 


ا مثال ذلك : 


مطلوب إضافة حقل الجنسية (يمني/أجنبي) 
لجدول الطلاب ا5 ومن ثم عرض البيانات في 
نموذج ۴٥۲۳‏ ؟ 


ولعمل ذلك لا بد أولاً من إضافة هذا الحقل 
بأمر 501 وكالتالي : 


alter Table Stu 
Add (Stu _ Nat number (1)); 


SQL> 


(إذا قمت بإنشاء الحقل بعد جلب البيانات 
إJl Data Block J| دııحتڊ pمقaف FormJl‏ 
(5۲1) ثم إنقر على زر الفأرة الأيمن لتختار 
ata Bloc) Wizard‏ ومنه التبویب 


Data Block Wizard × 


Tipe | Tee | 


Enter a lable or view on which to base your data block 
Then select lye colamns hal should appease as Rent: 


Table or view 
STU Browse | 
Refresh | ` Enforce data nlegily 


Database lems 


هاabا‏ ثم إضغط الزر #كهإfهR‏ وبعدها قم بجلب العنصر 51۷_١۸1‏ ثم إضغط نهاية) 


أو نقوم بإنشاء ۴0۲۳ تكون فيه ال)عها8 واة2 معتمدة على الجدول ل5۲۷ لنلاحظ أن الحقل ۸N۸۲_ل51۷‏ قد 
أخذ الشكل الإفتراضي للعناصر وهو ۴۳ا1 ۲٠×‏ . ولجعله بشكل ×80 C۸6٤)‏ نقوم بتعديل قيم الخصائص 


التالية : 


Property Value 

1 Name STU_NAT 
چ س‎ TT 
2 ا ا‎ 

|4 Valuewhen Checked) 1 

. 5 Value when Unchecked) O 

6 | Check Box Mapping of Other Values) Checked 

ا ت 57 چ 
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نلاحظ بعد ذلك آنه قد تم تکوین ×80 Chek‏ » 


وكذلك تنفيذ البرنامج وظهور القيم على شكل إختيارات متعددة بدلاً من القيم المدخلة كما في "1(۳ ٠6×‏ . 


لاحظ عمل کل من : 
° خlصيةö gar» Value when Checked‏ 
والتي ر تقوم باعطاء الإختيار | نش طا SARI b> aa CAS BShmX FF SAQ‏ ?2 
إذا كانت القيمة مساوية لحقل ES SSSR‏ 5 
SSS :. a= « STU_NAT‏ 
i FE .‏ = و ٤‏ 2 ك 2 ا بَا 
والتي ستقوم بإعطاء الإختيار العي r r CL‏ ر ر mm mk ml mM‏ 
نشط إذا كانت القيمة غير مساوية کک ت کت 
القيمة لحقل 511_۸41 » ا ل ترا 
Check Box Mapping of ثöةıصlخ ٠‏ 
Other Values‏ والتي ستقوم بإاعطاء 
الخيار النشط ٤)٥4‏ ٥م‏ أو الإختيار 
غير الط Unchecked‏ (حسبپ چڪ 


تحديد المبرمج) إذا وجدت قيمة في 
حقل ١۸۸_لا51‏ مغايرة لما ذكر في 
الخاصيتين السابقتين . 
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أنواع القماشغية Canvases‏ : 
القماشية تعني الخلفية (الورقة) أو الأرضية التي تتوضع عليها العناصر 165[ » 


ولها عدة انواع هي : 


Content .1‏ : وهي على مساحة النافذة التي تحتويها وهو النوع الإفتراضي حيث ينشأً عند إنشاء 
النموذج ۴۵۲۳ ويجب تعريف واحد من هذا النوع على الأقل لكل نافذة س0لہW‏ . 

Stacked .2‏ : ويظهر فوق ال 0te" °2 ۷2s‏ ويمكن التحكم بحجمه وكذلك إظهاره وإخفاؤه تلقائياً . 

Toolbar .3‏ اVertica‏ : وتظهر بشکل شریط ادوات عمودي . 

Horizontal Toolbar .4‏ : وتظهر بشکل شریط ادوات افقي . 

5. ھا: ویظهر بشکل صفحات ونحتاج له في بعض الأحيان لحصر العناصر في مجموعات . 


أمثلة ذلك : 


نقوم بإانشاء ۴۵۲۳ جدید یعتمد على )ها8 ة0 هو الجدول ل5۲۷ لنلاحظ أنه سيقوم ilıشlء Content J|‏ 
5 (إفتراضياً) وستظهر العناصر عليه وإسم ال )a"۷22( a65‏ ولیکن تسميته البرمجية 
CANVAS_CONTENET‏ « 


بعد ذلك نقوم بتحديد ال( ك5€ة۷١3))‏ الموجود في شاشة 


ال(Navigator‏ ectز0b)‏ تم Create‏ ثم نضغط ۴4 للتحکم بقیم - 
الخصائص التالية : Î CANVAS_CONTENT‏ 


2Ë CANVAS_STACKED_SEC 
2Ë CANVAS_STACKED_LVL 
!- j CANVAS_VERTICAL 

|. a CANVAS_HORIZONTAL 

2-- CANVAS_TAB 


+ 
+ 


Property Value 

1 Name CANVAS_STACKED_SEC 
2 CanvasType Stacked 
١ 3 | Viewport X Position) 25 
١ 4 Viewport Y Position 150 

و . 

. SE TTT 8 


ثم نقوم الآن بجلب بيانات الأقسام ٣١١‏ ا†ءع5 إلى داخل هذا ال Canvas‏ وذلك بتحديıد (Data Block )J|‏ 
الموجود في شاشة ال(0۲ھو Nav‏ ectز0b)‏ تم بزر الفأرة الأيمن نختار Data Bloc) Wizard‏ ونتبچ نفس 
دة 


الخطوات المعو 1 OO‏ 1 لنلاحظ بعدها توضع 
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وبنفس الخطوات السابقة ننشئ ال 
F56‏ الخاص ببيانات المستويات مع 
إختلاف : 


ه) التسمية البرمجية 
CANVAS_ STACKED_ LVL‏ « 
ط) جلب كتلة البيانات ا۷ا » 
ع) توضع العناصر على هذا ال كCa۷a١C‏ 
الحديد . 
نقوم الآن بإنشاء عنصرين من نوع 
Content CanvasJl Je Push_Button‏ 
مع مراعاة عدم وضعهما في أمكنة 
الئa۷se‏ المراد إظهارهم » 
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Layout Wizard × 


Select lhe canvas on which you wish to lay out the data 
block's items. If you ase creating a new canvas. also be 
sure to select the appropriate canvas lype. 


If you select a tab carvas, then you also mast select a 
tab page on which to lay oul the data block's hems 


| ية _[ دسس]| سب 


(لأن ال ٤Ca۷as‏ من نوع ed‌)tcھs‏ یتوضع على ال sھ۷a٣ھC٤‏ من نوع content‏ كما ورد ذلك سابقا) 


وذلك من أجل التحكم بإظهار أحد القماشيتين أو إخفاؤها . حالياً نجعل خاصية اعطه1 للزر الأول ( الأقسام 
وللزر الثاني (المستويات) وقبل كتابة الشفرة الخاصة بكل منهما فإننا نقوم إحتياطاً بإخفاءهما عند بداية 


تحميل البرنامج لحين الطلب وكالتالي : 


ثم نكتب البرمجة الخاصة بكل زر منهما 
ففي زر الأقسام نكتب : 


(Trigger : 
WHEN_BUTTON_PRESSED) 


Hide_ View ('CANVAS_ STACKED LV 
L') ¢; 


Show View ('CANVAS STACKED SE 
C') ; 


Go_Block('Section'); 


mat) 


(Trigger : WHEN_NEW_FORM_INSTANCE) 


Hide_View ('"CANVAS_STACKED_SEC') ; 


Hide _ View ('CANVAS STACKED LVL') ; 


r IE) 
3 ا اها إجراء تمرير اصتعلام تطمة مسجل حتل نانذة تمت‎ 
? SRG bP aa SOS ShaX FF G3Q 
مضه هم‎ 
£ KK KIS س س س‎ 
e TT عبد قرحمن عبد قول‎ | 
cT مە قمر قاط‎ | 
سم‎ | GI TI 
Frye KE KI بم مد طت‎ 
بعت وقم‎ 
تر تسر‎ 
1 — im 
ا‎ 
]نہر‎ 
آنعت‎ 
کے‎ ETT | 


Execute _ Query; 


وفي زر المستويات نكتب 
(Trigger : WHEN_BUTTON_PRESSED)‏ 


Hide View ('CANVAS 


Show 1 1 
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Go_Block('Lvl1'); 


Execute_ Query; 


بالطبع بعد إظهار الئة۷"ة) الذي نريد نذهب إلى ها8 هاه( التابع له تن نجلب البيانات بالإستعلام . 


الآن ويعد إنجاز هذه المرحلة نريد إنشاء عناصر تحكم (أزرار) على شريط الأدوات العمودي وكذلك شريط 

الأدوات الأفقي [ التي يفضل إنشاؤها في كتلة بيانات غير معتمدة على قاعدة البيانات ١0٣۸_08‏ 
] خاصة بالجدول ل5۲۷ وبالطبع لن يتم هذا أو ذاك إلا بتحديد ال(ئعكة۷١a))‏ الموجود في شاشة ال( زط0 
)Navigator‏ تم عatعاC‏ مرتين مع مراعاة الخصائص التالية : 


Value 


CANVAS_HORIZONTAL 


Property 


Name 


Property Value 
1 | Name CANVAS_VERTICAL 
و اا ا‎ 


فمثلاً نجعل أزرار شريط الأدوات العمودي ( حفظ - إستعلام - خروج ) ونجعل أزرار شريط الأدوات الأفقي 
(الأول - التالي - السابق - الأخير) بعد تغيير ا6 ةا الخاص بكل زر منهم بالإسم الظاهر عليه ونكتب 
الشفرة الخاصة في حدث WHEN_BUTTON_ PRESSED‏ بالأزرار كالتالي : 


(PUSH_BUTTON_PREVIOUS) 
Go_Block ('Stu') 


Previous_ Record ; 


(PUSH_BUTTON_LAST) 


Go_Block ('Stu') 


(PUSH_BUTTON_ FIRST) 


r 


_Block('Stu') 


First _ Record ¢ 


Go 


; (PUSH_BUTTON_NEXT) 


r 


_Block('Stu') 


Go 


(PUSH_BUTTON_SAVE) 


Commit_ Form ; 


(PUSH_BUTTON_QUERY) 


Go_Block('Stu') 


Execute_ Query ; 
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حاضرات فی اُوراکل دقلویر أ6 ORACLE‏ 


(PUSH_BUTTON_EXIT) 


Exit Form 7 


EEA CANVAS_TAB 


F-9 PAGE_SECTION 


@- PAGE_LVL 

2-Ê PAGE_STU 2 e 
2-Ê PAGE_SUBJECT = = جا ت‎ 
&- J PAGE_MARK e 


النوع الأخير من أنواع ال كة۷١ة٤‏ هو النوع ط12 وفي هذا النوع يتم أولاً تحديد ال( ك6ئة۷١3٤)‏ الموجود في 
شاشة ال( Navigator‏ ectز0b)‏ تم Create‏ تم نضغط ۴4 للتحكم بقيم الخصائص التالية : 


Property Value 

1 Name CANVAS_TAB 
2| CanvasType) Tab 
. 3 | TabAttachment Edge | Top 


لنلاحظ إنشاء ثلاثة صفحات إفتراضية ومن الممكن جعله يتكون من عدة صفحات (ضمن مجموعة) لذلك إذا 
أردنا إنشاء صفحة جديدة فنقوم بتحديد ال( كمكة۷"ة٤)‏ الموجود في شاشة ال( 0أNavig2‏ اecز0b)‏ ومنه 
iحıı (Tab Pages)J|l‏ تم C۲٥۵٤‏ ثم نضغط ۴4 للتحكم بقيم أهم الخصائص مثل |[ التسمية برمجية - 
التمكين وعدم التمكين - العنوان - الإظهار والإخفاء ] . 


تسام | البستويات | الطلاب | المواد ‏ | الدرجات 


Property 
رقم المادة المادة ننم القرقم المستورنم الطالب‎ 
2 Je f 
1 | Name 1 mE mm یجول بیساك‎ | ٣ 
mm Ki mı: اغرنسية‎ | ۲ 
ع إادوائية |" 1[ [ اج‎ 
2 | Enabled ت‎ mm mm ۱ 


| Jihomrenourat oY] 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


تم نقوم الآن بحجلب بیانات الأقسام ×= Layout Wizard‏ 
Section‏ إلى داخل هذا ال ك۷2a٣ةC‏ وذلك د ماه راداب مرا د سد م یچ 

بتحديد ال( )0ا8 هاة0) الموجود في oS‏ 

Canvas: [CANvVAs_Tas 3 تم بزر‎ (Object Navigator شاشة ال(‎ 


الفأرة اليمj‏ iختliر Data Block Wizard‏ سس ي 

ونتبع نفس الخطوات المعهودة إلا خطوة 

توضع العناصر فنختار a e hp ry rm ee › CANVAS_TA8 JI‏ 
وبما أنها عبارة عن صفحات فيجب أن نحدد 
PAGE_SECTION aãanيقallı Tab Pages‏ 
(وهو الإسم البرمجي لهذه الصفحة) 
لنلاحظ بعدها توضع العناصر على هذا ال 
Canvas‏ „ 


Tab Pag [HEBE 


| نمية _[ قتي ]| سبو 


شمن اأخطواة المسارفة تحاف ال فوا8 قاذ الخاهة هة الحداك ألى الحككة الخهةة تة على ال 
r2 565‏ کل بما يناسبها . 


نلاحظ أن ال )٤0ا8‏ ها0 قد يتم جلبها أكثر من مرة على إعتبار وجوب توضع عناصرها على C3۸۷85‏ جديدة 
لذلك قد يتفير إسم Data BOCK J|‏ مثلاًَ SECTION jn‏ إلى SECTION1‏ وهذا لا يعني Data Block J| iİ‏ 
المسماة 5٤٤۲10۸1‏ ليست موجودة في قاعدة البيانات فهذه أسماء إختيارية ولكن المهم هو أن تكون 
الخصائص لها كالتالي : 


Property Value 
1 Database Data Block Yes 


2 Query Data Source Name SECTION 


وكذلك حقول هذه ال )0ا8 اه0 يجب أن تكون الخصائص لها كالتالي : 


Property Value Property Value 


1 ¦ Database Item Yes 1 | Database Item Yes 


وبمعرفتنا لهذه الخصانص يصبح من الممکن إنشاءا‌ه‌ا8 دة تعتمد على قاعدة البيانات 08 


يدوياً 
fata WON‏ وأجلنا ورود هذه الفقرة) 
N‏ 1 1 67 
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حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


ه٠‏ من الممكن التحكم بخصائص ال C١۷35‏ برمجياً من خلال التعليمة التالية : 
' (لSet_Canvas_Propertyإسم‏ القماشية , 'إسم الخاصة , القيمة ( 


٠‏ يمكن التحكم بخصائص الصفحات برمجياً خاصة إذا أردنا منع إظهار صفحة ما على مستخدم معين وذلك 
من خلال التعليمة التالية : 

Property( "‏ _eوPa_طa‏ ا _Setكإسم‏ الصفحة , 'إسم الخاصية , القيمة ( 

متثال : 


Set _Tab_ Page Property( 'PAGE MARK' , Visible , Property False ); 


وفي هذه التعليمة إشارة إلى أنه لا يمكن أن يتكرر إسم صفحة ما حتى إذا كانت في طه1آ 
Canvas‏ حدیدة 


. ٤ة"۷ةئكلا على كCan۷a أخرى سيظهرها حتى إذا لم نكتب أمر الإظهار على‎ Data إستدعاء ال )عا‎ ٠ 


٠‏ عند التنفيذ تتوضع أولاً ۲٥0(۲ ٥3١۷55‏ ثم تأتي بقية العناصر في الجزء المتبقي من النافذة لذلك يجب 
مرlعölE Horizontal Toolbar J| aè Height J| dJiSs Vertical Toolbar J| „è Width‏ . 


ه٠‏ إذا أنشئت أي عنصر ۳[ في كة۷١ة)‏ معينة وأردت نقلها إلى ٥١۷a‏ أخرى فما عليك سوى تغيير 
خاصية ال كة۷١ة)‏ لذلك العنصر بجعلها تشير إلى ال C١۷5‏ التي تريد . 


۰ من الممکن رسم أیقونة 1٥0١‏ علی کل زر ٣۸_B8Bu††0ءں۴‏ بعد تعدیل خصائصه بحیث : 
ه. تعطى القيمة ۷6١‏ لخاصية Iconic‏ 
ا. يعطى إسم لملف الايقونة ذو الإمتداد Icon Filename öةيصاlخنllل *.ic0‏ . 


٠‏ خاصية rab Attachment Edge‏ تعمل على تحديد الموقع الذي ستظهر فيه التبويبات الخاصة بدخول 
الصفحات وتمتلك lلقيم (Top _ Bottom _ Left _ Right _ Start _ End)‏ . 
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حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


الكاهعرة اتات 


:_ Report Builder % 

أداة تستخدم لبناء التقارير التي يستخدمها ال(8۲ءلا) بكل عناصرها » ومثل ما قمنا بكتابة البرامج والتحكم 
بصلاحيات المستخدمين وإنتقاء أفضل الواجهات والأساليب لكتابة البرامج وأداء العمليات المختلفة عليها فإن 
التمرة التي يجب أن يجنيها البرنامج هي التقارير والتي لا بد من أن تكون ببرنامج ال de۲|أ 8u‏ ۲ 0معR‏ » وقد 
ذکرنا سابقاً أنه عند عملیتي : 


Report Builder جمliرڊ ويشغله‎ *.R D۴ ذو إمتداد‎ 501۲٥٤ حفظ التقریر 53۷۴ يتولد ملف مصدري‎ ٠ 
. Reports Runtime جمliرڊ‎ aلغشيو‎ *.R٤۲ الترجمة عاام۳٥) يتولد ملف تنفيذي عاں٤ع×E٤ ذو إمتداد‎ ٠ 
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: Report Builder Jaa % 
مرحباً بك فى بانى التقارير‎ ۰ xl 3A Start > Programs > Oracle Reports 
ين تبداً-‎ 6i-orantr > Report Builder 


فتظهر أولاً شاشة ترحيبية يمکن من خلالها 
تحديد ما إذا كان المطلوب البدء بالتصميم أو 
بالتعليم » فالة ثلاث خبارات 


۹ | تخدام معالج التقارير › ([عرض الجولة السريعة [مغاهيم ) انعليم ® 
۰ بناء تقریر حدید يدوياً › | لاا کے اا او عرض عند بداية التشغيل ۲ 
٠‏ فتح تقریر موحود مسبقآ › 


یناء تقربر جدید یدوا ١‏ 


فتح نقربر موجود ° 


وللتعلیم خباران وهما : | تيمت _ | تة | 


› عرض الجولة السريعة (مفاهيم)‎ ٠ 
. إستكشاف كروت التلميحات (مهام)‎ ٠ 
(حالياً سنختار البدء بالتصميم بإاستخدام معالح التقارير ثم‎ 


نضغط 0۸) 
× 
لتظهر بعد ذلك شاشة ترحيبية خاصة بمعالج التقارير (فنضغط اننبا في اسكخدام معالع الكقاري 
التالي) لتقارير من بداية سريعا مخظفة دقاریر انوا عد تکمین لے ب يساعدك المعالح 
المعتدة المصفوفة تتقارير إلى البصيطة الجدولية 
ثم تظهر شاشة نعطي فيها العنوان العام الذي سيظهر على سلود چن رمد تیه سی ی مو بم ااه 
5 للمتابعة 

التقرير وكذلك نقوم بتحديد نوع التقرير هل هو : ا 

۰ جدولي » 

F qare . يشبه النموذج‎ ۰ 

۰ عنوان بريدي › 

تحمح لسار اآ # ا[ a‏ 

© ڪي 

© 

© 


4 jlyahawiOhotmailt) 


معالج 


التقرير 


حاضرات نی اوراکل دىفلویر أ6 ORACLE‏ 
(حاليآً سنختار سنكتب العنوان تقرير بيانات الطلاب ونختار نوع التقرير حدولي ثم نضغط التالي) 


× معالج التقرير معالج التقرير 


ثم تظهر شاشة تحديد نوع الإستعلام هل 


ه جملة SQ)‏ › 

۰ اإستعلام sئ6ام×٤‏ (عندما یکون علی 
ةة (Server/Client‏ „ 

(حاليا سنختار نوع الإستعلام من 

حملة 5Q1‏ ثم نضغط التالي) 


ااع و رها فة کي من خلاعا خماة الأس هاا التي ا غلا كي الساات قى الري جوت 
يمكنك تحريرها مباشرة في ,ا€‌Qu@‏ ا5Q‏ 

Statement‏ أو بناءها من جدید من خلال 

برنامج باني الإستعلام Build SQL Query...‏ کسیر اسنلا تکریل او 50 اعدم نة او مرجره تما استيا 
أو إستیرادھا من Import SQL Query... ¡le‏ بجملة الاستعلام 
دهناك آبخا زر الاتضاك إت لم تكن منصلا ل 

Connect... ةدعlaلlب‎ 


ممالج التقرير 


2 
= م 
51/42 :اسم المستخدم 
| :كلمة السر | هاه | < التالی الممابق > 
o.‏ :فاعدة البيانات 


(حاليا سنقوم ببناء حملة الإستعلام من خلال الضغط 
على البرنامح المصغر باني الإستعلام...) 


حيث لابد من الإرتباط أولاً بقاعدة البيانات وكتابة إسم ال( #۲كلا) وال( )۴۵55W0۲٩‏ بشكل صحيح ومن ثم 
الضغط على الزر وصل ولتظهر الشاشة الخاصة ببرنامج باني الإستعلام ومنها شاشة إختيار جداول 
البيانات المراد التعامل معها (حالياً سنتختار الجدول 5۲۷ ) ونقوم بالتأشير أمام كل حقل نريد جلبه أما إذا 
أردنا جلب جميع الحقول فنؤشر على الخيار المتعدد أعلى الجدول » لاحظ على شريط الأفقي لبرنامج باني 
الإستعلام وجود الأبقونات : 


٠‏ إختيار حدول البيانات : عندما نريد إظهار هذه الشاشة مرة أخرى لإضافة جدول آخر ء 
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حاضرات فی اوراکل دفلویر أ6 ORACLE‏ 


. إظهار 501 : لنشاهد من خلالها تكون آمر الإستعلام‎ ٠ 


E uy ii yS لاا‎ n a n داع‎ 
QS PTB Hao A FOS Vx êê W3 APSE b7 007| o RR xX ER. 
8 = 
E 


SELECT AA STU STU RO. ST STU NARE, 
|STUSTU_SEC, STU. STU_Lv 

STU STU _ADO. STU STU ARNOT. 

STU STU-AVG. STU STU_CERTITYPE 

Fnom sU 


(نضغط موافق ولنرى تكون حملة 
الإستعلام مباشرة في yإQue‏ 5۵1 
Statement‏ فنضغط التالی) 
وبالتالي تظهز الحقول في ال(ا8ق قتخطار متها الحقول المطلوب التعامل مها بواسطة الأزرار < خخ اء 
<< 
(حالیا سنختار << ثم نضغط التالي) 
E‏ × رر 
بعد فيما آخرى حقول إضافة يمكنك تقريرك فى عرضها تريد التى الحقول اختر TEE. rege re TT j are e er‏ 
Avalable Fields Displayed Fiekds‏ 
ا2 STU_NO‏ 5 
SELECT ALL STU.STU_NO, STUSTU_NAME, STU.STU_ SEC 2 A E‏ 


STU.STU-ADD, STU.STU_BATHOT, STU.STU_AVG 
STU.STU_CERTTYPE 


ol STUN 
0م || ر‎ 


3 STU_BRTHOT 
< 3# STU_AVG 
ل‎ < [STU CERTTYPE] CERTTYPE 


| وصل 0 اصبتیراد اصتعلام انى الاصتعلام 


ا mg r‏ 
| | هة السابق > تعلیمات | إلغاء | تة | <اتاتي ]|| السابق> 


لتظهر شاشة حساب إحماليات الحقول التي ترغب بإيجادها مثل (المجموع- المتوسط - العد - الحد 
الأدنى - الحد الأقصى - الإحمالي) وذلك من خلال تحديد الحقل ثم ضغط الزر الذي تريد تطبيق الحساب 
المراد إجرائه عليه > 

(حالياً نضغط التالي) 

ثم تظهر شاشة تمكننا من تغيير العناوين الظاهرة لأسماء الحقولام ۴۲١۳١‏ وكذلك عرضها ۷ وطولمها ١‏ 


, 4 alawiChonai 


(حالياً نضغط الت 


× معالج التقرير 


لتظهر شاشة تحديد القالب عأةام”٣٠٠‏ الذي 
تريد عرض التقرير به فيمكنك أن تختار : 


© قالب محدد مسبقاً › 


ORACLE 


× معالح التقرير 


.والهيكل العرض »الخها الأبتاها »القالب لون صيرث تقريرك لتقريرك قاب اختر 


Corédenlisl Û sek ground 


ا= Cyan Gıid‏ 
يلف قالب ° 
| امستعر اض 


لا یوجد قالب ° 


| ميه ل دي ]| سبق 


» تحديد قالب من ملف مخزن على جهاز الكمبيوتر الخاص بك‎ ٠ 
ظهور التقرير بدون آي قالب . (حالياً نجعله على القالب الإفتراضي تم ضغط التالي)‎ 


بعدها تظهر شاشة التهاني والتبريكات ١5‏ ٥ناداناةإو١هء‏ لتعلن عن إتمام معالج التصميم (المخطط) بنجاح > 
(فنضغط نهاية) وبذلك نكون قد قمli‏ بتشJı RepOrt Builder‏ . 


= 
تقريرك وصف من انتهيت لقد اتهانينا 
الحية المعاينة فى وعرضة التقرير بتكوين المعالج سيقوم آتهاء نقر عند 


زر انقر ببساطة موجود تقرير اتعديل التقاربر معالج ادخال إعادة أيضايمكنك 
ر ا ار ا شر ار ودوت کر کی ایر سم 


× 3 معالح التقرير 


.والهيكل العرض الخعا »لأبتاها »القالب لون صيرث تقريرك اتقريرك قالب اتر 


حاضرات نی اوراکل دىفلویر أ6 ORACLE‏ 


۰ يتم تشغیيل التقرير من خلال جلب البيانات من ال ٥5ةطهاة0‏ سواءً أكانت قاعدة البيانات موجودة على ال 
Server‏ او على ال ientاe)‏ (لاحظ هنا تنشیط ال Activity‏ ientاC‏ والذي يعني حلب البیانات من 
قاعدة البيانات الموحودة على ال غ iاC)‏ ء 

٠ه‏ في حالة عدم ظهور الخط بالعربي قم بتغيير الخط وذلك بالضغط على ٤١۱+۸‏ لتحديد الكل ثم من 
شريط الأدوات الأفقي قم باختیار نوع الخط ولیکن ۸۲۵61٤٥(‏ )ا۵ا وحجم خط وليكن 12 › 

٠‏ بالإمكان تغيير الصورة الظاهرة في هذا القالب بصورة أخرى (مثلاً شعار الجامعة) وذلك بإختيارنا الأمر 
إستيراد ومنه صورة من القائمة ملف . 


N1 MODUL ROR N E EE E‏ ⁄ اني تالاير اندوز 
تحت صيخة اضانة هرضي تعرير rs‏ 


“E 
3 
1 


OF‏ نشکیل صفحة1 
4 
aT 5i‏ 
my‏ ن ا 0 
Client Activity Server Activity mM‏ 
#۳ 
Qis ooo‏ 
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حاضرات نی اوراکل دىفلویر أ6 ORACLE‏ 


*٭ الشاشات الرئنيسيã‏ نلنلف)ز Report‏ 


Object Live 
Navigator Previewer ¢ Builder 
: Object Navigator .1 
ويحتوي عناصر التقرير كاملة أ۲ممع۸R وكذلك الكائنات ا‎ 
Report Builder Model ومن الممکن الحصول على هذه الشاشة من‎ . bjet 
Design Tools خلال الضغط على الزر ۴3 او من القائمة كا0٥۲ نختار‎ 
. Object Navigator رمٺJl‎ 
PL/SQL Layout 
Editor Model : Data Model .2 
نموذج البيانات وسناتي إلى شرحه بالتفصيل » بإمكانك ا‎ 
۴0" في برنامج‎ Data Bاoع)‎ W¡iz24 إعتباره شبيه ال‎ 
„ Builder 


Layout Model .3‏ : 
نموذج النسق وسناتي إلى شرحه بالتفصيل . بامكانك إعتباره شبيه ال W224‏ 201ا في برنامجح ۴0۲۳ 
Builder‏ „ 


: Property Palette .4 

وتحتوي خصائص العناصر والكائنات كاءعزط0 . ومن الممكن الحصول على هذه الشاشة من خلال الضغفط 
علی الزر ۴4 أو من القائمة ڪا10o‏ iخliر‏ لمر Property Palette‏ . 

ملاحظة هامة : 


نموذج البيانات ال50 ها0 ونموذج النسق اعMod‏ ayoutا‏ هما مكوني م| ڀسمJ Report Editor Jl‏ . 


نبذلةمسطة عن محتويات Object‏ خقاریو 5 
SS] HODULET1 .‏ 
REM. : Navigator‏ 
> نموذج بيانات 4 ٠‏ 
Reports‏ : نموذج نسق |[ + 
نموذج معاملات [ب» --1+ 
. زناد التغارير +1٠‏ 
1. [حالیاَ MODULE]‏ ] : إسم ال (ااoمعR)‏ الإفتراضي ويأخذ إسم a e A‏ 
البرنامج دوماً › SQL Queri‏ 1 1 
Live Preview .2‏ : وهي لمعاينة التقرير قبل الطباعة » 1-PLASQL Libraries‏ 
Data Model .3‏ : نموذج البيانات وسناتي إلى شرحه بالتفصيل » E. o EHRE‏ 
Layout Model .4‏ : نموذج النسق وسناتي إلى شرحه بالتفصيل » ایریا ر ا 2 
Parameter Form .5‏ : نموذج المعاملات وھو عبارة عن ۴۵۲۳ یظھر 


النظام . 
Reports Trigger .6‏ : وهي عبارة عن (ا1/5Qا۴‏ , اSQ)‏ ینفذ عند 
حدث معين قد يکون هذه الحدث : 
٠ه‏ قبل نموذج المعاملات Before Parameter F0]™‏ « 
هه بعد نموذج المعاملlۈاٽت After Parameter FO0'm‏ « 
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| MD #& | DO 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


Attached Libraries .8‏ : وهي عبارة عن مکتبات ا1/5Q۵ا۴‏ » 
atesاrempP‏ : عندما تنشئ تقریرآ بشکل قالب » 


› الخارجية‎ 5Q) إستعلامات‎ : External Q1 Queries 

» ۴1/؟Qا وهي عبارة عن مکتبات‎ : P]/SQ1 Libraries 

› للتنقیح‎ : Debug Actions 

> إستخدام المكدس‎ : St) 

» وهي عبارة عن الحزم المدمجة مع ال(عاءةا0)‎ : Buiاt-in‎ Packages 


. حیث تقوم بعرض جمیع مستخدمي قاعدة البیانات‎ : Database Objects 


ك ملاحظات هامة : 
.۰ × 


ه٠‏ أثناء عملية الحفظ ه۷ةŠ‏ < #اأ۴ تظهر شاشة خيارات الحفظ ‏ أ حفظ علي 
والتي من خلالفا يمكنك تخديد إذا ها كنت تريد الحفظ في فاعدة ابياناك °| 
قاعدة البيانات أو في ملف (الإفتراضي) وكذلك هل تريد الحفظ ا 
لعرض التقارير (الإفتراضي) أم القوالب أم الإستعلامات أم 2 
المكتبات التابعة PL/SQL JJ‏ ام حفظ الكل » تقاریر ا 
(خالنا نظ مواقى لتم حخفظ التقرير على ضاف تكد e‏ 
مساره) استعلامان ۳٣‏ 
مگثہاٹ ۴1/501 |٣‏ 


0 وبنفس المنوال تظهر شاشة شبيهة أثناء عملية الفتح ۵۸م‎ ٠ 


لتقرير ما . اا 


 qlyanawiOnotmail et) 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


: Data Model نموذج البيانات‎ * 

حيث نقوم بتحديد ال( اعلهM‏ هام0) الموجود في شاشة ال( اععزطO a EEE‏ 
atorوNavi)‏ ونضغط ۴2 لتظهر نافذة فيها الإستعلامات الموجودة للتقرير (حالياً Hj BACKGROUND‏ 
)Q_1‏ وإذا نقرنا عليها نقرآ مزدوجاً يظهر الإستعلام والمرتبط بمجموعة من Sl‏ 

i) DECIMAL الحقول‎ aFrzEr ×اعلر‎ 


× اا : 
DESFORMAT‏ 
?7 2/0 0013 38 متواجدة على e‏ 


شكل مجموعة mH] DESTYPE‏ 
HE] MODE 2‏ 
TW] ORIENTATION . Group‏ 
E] PRINTJOB‏ 
EH THOUSANDS‏ 
معاملاٹ مسنخدم 
اسنعلامات 1۰ 
E Q_1‏ 
مجمو غات 1۰۰ 
Ê G_STU_NO‏ ® #1 
أ عمدة الصيغة 
أ عمد الملخص 
أ عمدة منثغير التعويض 11٠‏ 
روابط البيانات 


ولنلاحظ أن محتويات نموذج البيانات 1ءلهM‏ هاه( كالتالي : 


۾. معاملات illزظlم System Parameters‏ _: 
حيث يتم التعامل معها عن طريق الخصائص الخاصة لكل معامل نظام (نحدد معامل النظام ومن ثم نضغط 
على ۴4) وخاصة خاصية القيمة الإبتدائية عمu‏ اه۷ 1ه1)آ"1 ومعاملات النظام هي : 


1. dlلخlلdغيıة Background‏ : 
(إفتراضياً قيمة خاصية القيمة الإبتدائية ۸0) وعندما تكون ۲۴5 فإننا نجعل التقرير يطبع في الخلفية بينما 
نحن نواصل العمل في برامج اخرى » 


2. عدد النسخ sع‌opi‌C‏ : 
وتعني تحديد عدد نسخ التقرير المطبوع (إفتراضياً قيمة خاصية القيمة الإبتدائية 1) › 


3. ellعeمal Currency‏ : 1 1 
وتعني ما هو الرمز الذي تريد إضافته بجانب الأرقام أتناء طباعة التقرير (مثلاً نكتب ۷.۸ أي ريال يمني) › 


4. الفغواصل العشرية اج" ام0٥‏ : 1 
وتعني تحديد الرمز المستخدم مع الفواصل العشرية (مثلاً نكتب الرمز , أو الرمز » أو الرمز .) » 


5. تنسیق المد و ¬ g„Des:۴۲‏ _ 
Jaan a‏ أو سیف ۲۴ أو ملف 
i‏ 1 1 76 
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6. إwم‏ JlلgدJAک DesName‏ : 
وتعني تحديد إسم الملف الذي سيرسل إليه التقرير (مفيدة جدآً إذا لم تكن هناك طابعة مرتبطة بجهاز 


الكمبيوتر) › 


: DesType Jدھلا نوع‎ .7 

وتعني تحديد وجهة الطباعة هل هي إلى الشاشة ١٠٠۲ء5‏ ام إلى الطابعة ع١۴۲‏ ...إلخ (بالطبع الطباعة 
إلى الشاشة أسرع من الطباعة على الطابعة بسبب أن ظهور الصفحة الأولى من التقرير على الشاشة 
لايستغرق وقتاً طويلاً بينما ظهور الصفحة الأولى في ورق الطابعة يتطلب أولاً تنسيق جميع الصفحات قبل 
البدء بعملية الطباعة) › 


8. lلaiمط Mode‏ : 2 
وتعني تحديد ما إذا كنت تريد ان يطبع تقريرك بشكل صورة 2۳" Bi‏ |۾ |حرز Character‏ « 


9. Jlۈiجol Orientation‏ : 
وتعني تحديد إتجاه طباعة التقرير هل هي آفقية ع#مةءءل" ها آم عمودية Pora‏ « 


0. وظيغة الطابعة اه3ا"1ا" : 
وتعني تحديد هل نريد إظهار شاشة خصائص الطابعة قبل التقرير آم لا (إفتراضياً قيمة خاصية القيمة 
الإبتدائية ۲65) › 


11. JÎJIۈف Thousands‏ : 
وتعني تحديد تنسيق الآلاف (متلاً 99.999) . 


ط. معاملات تخد User Para mete1s‏ : 
وطريقة إنشاء معامل مستخدم يعتمد إعتمادآً كلياً على جمlة‏ lلۈwۃتeعlںۈم SQL Query Statement‏ « 
والتي نصل إليها بتحديد (Data Model )J|‏ 

الموجود في شاشة ال( re ### Object‏ 
pû (Navigator‏ : ج 


E نضغفط ۴2 لتظهر نافذة فيها‎ ٠ 
e EEE الإ 2 امات الموحودة للتقرير (حالياً لد اوا‎ 
فننقر علیها نقرآً مزدوجاً لیظهر ی‎ )9_1 
HEE الإ ام › ا‎ 
تم ال‎ Que e5 أو نحدد الإستعلامات‎ ٠ 
DS E . نضغط ۴2 وينفس الطريقة‎ 
- | لنقم بإضافة معامل مستخدم وذلك بتعديل‎ 
ونكتب فيها ت‎ )Q_1 جملة الإستعلام (حاليً‎ 


1 


Where STU_SEC = :SECN‏ لصب 


لدينا الآن معامل م جدید ION‏ 


التأكيد الي تخبرنا بأنه قد تم إنشاء 
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نقوم الآن بتحديد معامل المستخدم الجديد S٤٣١‏ ونمنحه الخصائص التالية : 


× قاثمة مركبة لمعاملات 


قائمة مركبة 

تقيبد قائمة لقيم محددة من قبل ۴ SELECT le‏ @ قيم مياكئة ° 
Value EE‏ 
إخقاء العمود الأول ۲٣‏ :جملة استعلام 1ا50 


SELECT ALL SECTION.SEC_NO, SECTION. SEC_NAME ك‎ 
FROM SECTION 


حيث نعطي نوع البيانات ع#م۲۷ ة0 لمعامل المستخدم S٤E€۸N‏ القيمة 
Number‏ ونهيئه بقيمة إبتدائية عuاة۷‏ اهتاا١]‏ هي 4 وكذلك نحدد قيمة 
خاصية القائمة المركبة مuاج۷‏ fه‏ وأا من خلال الشاشة التي نحدد 
بواسطتها أن القائمة المركبة تجلب قيمها من قاعدة البيانات أي ديناميكية 
(حملة اهاه5) ومن ثم نقوم بجلب جملة الإستعلام عن طريق زر برنامج 
باني الإستعلام وبالطريقة الموضحة لدينا مسبقاً أو كتابتها مباشرة في 
محرر جJn‏ llلۈeawعںۈpم‏ ; Select * From Section‏ « 


والآن لاحظ عند تنفيذ التقرير كيف تظهر شاشة إعدادات الطباعة وهي 
محتوية على معامل المستخدم الخاص بالأقسام ١0ا56‏ والمسمى 
S۴۸‏ . ولنختار القيمة التي نريد تم نضغط Ente‏ . ولاحظ نموذج 
المعاملات ۴0۲۳ arame‏ عندما نقوم بتحدیده تم نضغط ۴2 لنشاهد 
الشاشة التي تظهر معاملات التقرير كاملة ۴0۲۳ , 


وينفس الطريقة إذا أردنا إضافة معامل مستخدم خاص بالمستوى تكون_ 
الخطوات كالتالي : 


1. إضافة المعامل عن طريق تعديل جملة الإستعلام فنكتب فيها 
SEC = :1VLN‏ 1اا "nee‏ ولیصبح لدینا الآن معامل مستخدم جدید 
LVLN g®‏ « 


2. تعديل خصائص المعامل (نوع البيانات - القيمة الإبتدائية - القائمة المركبة والتي نجعلمها إستاتيكية 


Property 


Data Type 


نموذج بيانات 4ء 

معاملات النظام + 

: 
j SECN 


استعلامات + 
مجموعغات + 


أ عمدة | الصيغة 
أ عمدة الملخص 
رواہط البیانات 
نموذج نسق 3 
نموذج معاملات ٣‏ 
1 
E PF_SECN1‏ 
قالب رسومي 
قالب النص -¬- 
T P8_3‏ 
T P8_4‏ 
T PB_SECN1‏ 
زناد التقاربر 
Program Units‏ 
Altached Libraries‏ 


قيم تابتة ] عن طريق كتابة القيمة تم الضغط على الزر إضافة وهكذا بالنسبة لبقية القيم) . 


] 


LLI 


E 


تقييد قائمة لقيم محددة من قبل ٣‏ 


حاضرات فی اوراکل دىفلویر أ6 


قاثمة مركبة لمعاملات 


انمه مرکنه 
جeلة C^ SELECT‏ قيم ساكنة © 
1 ] << إضانة 4 
2 
3 
بزهة 


ن أجل ذ معاملات illزظlم System Parameters‏ 
من قائمة أدوات نختار الأمر باني نموذج معامل ... 


Parameter Form Builder...‏ < sا00ا‏ لنشاهد 
وجود جınعg‏ laمlںڻت‏ illز¡ظpl“ System Parameters‏ 
ومعاملات المستخدم l|lلnمûiiة User Parameters‏ « 
فنقوم بتحديد المعامل الذي نريد ظهوره ( يصبح 
مظللاً أسود اللون) ونكتب أمام كل معامل العنوان 
الذي نرغب في إظهاره فمتلاً بدلاً من ظهور معامل 
المستخدم (القسم) بالعنوان S٤)‏ نجعله رقم 
القسم » ولتظهر رسالة تأكيد إختيار المعاملات 
ولنشاهد في نموذج Jllمleمںlۈاٽت‏ MڵFO0 Parameter‏ 
كيف تنضاف إليه بقية المعاملات التي قمنا بإنتقائها . 


لداعل 


[× اھا مف تحرير مرض تطبمت 


xy PF 


maie 


فی شاشة اعداد التق 


ORACLE 


Ir IBZulEERR 


TIE RTIRTTET 


معاملات اشرير] :غنوان 
أډخل یم امعاملان] :غنوان 
:سطر الحالة 


:مغامل 
ك موقر عدر DECIMAL‏ 
| س ORIENTATION‏ 
اتشغيل دي لخلغية BACKGROUND‏ 
طورااخدات MODE‏ 
حوار وظيفة الطباعا| PRINTJOE‏ 


| لفوةج مفايلت انبشفل 40000٤1‏ . ۸1 / بائي انشفارير لو يندوز ١‏ 14 
3 


oil 
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تلمىح : 


إذا أردنا أن ننشئ تقرير يعمل على إيجاد بيانات من رقم إلى رقم معين أو من تاريخ إلى تاريخ معين فإنه 
يجب علينا أن نقوم بتعريف معاملي مستخدم بواسطة تعديل جملة الإستعلام ومن ثم تعديل خصائص 
المعاملين (نوع البيانات - القيمة الإبتدائية - القائمة 


۱ المركبة) . ك‎ 
Warming: This wil replace your exãsling pa foam 4A : مثا ذلك‎ 3 
en 


بالإضافة إلى تحديد المستخدم للقسم أثناء إيجاد تقرير بيانات 
الطلاب فإننا نريد أيضاً جعل المستخدم يحدد المستويات بحيث تكون عملية التحديد من مستوى إلى مستوى آخر ؟ 


ولعمل ذلك فإننا سنقوم بما يلي : 


SQL Query Statement مpڼںlaiwۈll‎ ةle>ج‎ لJيدعت ه. إضافة معاملي مستخدم عن طريق‎ 
And STU_Lvl Between :No1 and :No2 öبlتكڊ وذلك‎ 


وليصبح لدينا معاملي مستخدم جديدين هما ۸01 و ۸02 . وذلك بعد ظهور رسالة التأكيد التي تخبرنا بأنه 
قد تم إنشاء المعاملين من قبل المستخدم ؟!!.. 


ط. نعطي المعامل الأول والمعامل الثاني الخصائص التالية : 
Property Value Property Value‏ 


1 Data Type Number 1 | Data Type Number 


ولنظهر عبارة (من مستوى رقم) أمام المعامل 01 وعبارة (إلى مستوى رقم) أما المعامل ۸102 وذلك 
من خلال قائمة أدوات نختار الأمر باني نموذج معامل ... Tools > Parameter Form Builder...‏ 


لنشاهد وجود جميع معاملات النظام كإعاعمصaاPa System‏ ومعاملات المستخدم المنشثة ١۴عكئلU‏ 
Parameters‏ . فنكتب أمام المعامل ١0٥1‏ العنوان (من مستوى رقم) وأمام المعامل ١02‏ العنوان (إلى 
مستوی رقم) . 
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حيث نقوم بتحديد ال(اعdهM‏ outرهL)‏ الموجود في شاشة ال0 0اaوNavi‏ tععز0b)‏ ونضغط ۴2 لتظهر الشاشة 
المحتوية على هيكلية العرض (الهيكل الرئيسي للتقرير ) أي المحتوي على الحقول كا۴ والعناوين 
ا8ا » ويمكن أن نتتبع مكونات نموذج النسق اعلM0‏ مھا من خlاJ‏ شlشة (Object Navigator )J|‏ Îو‏ 
شريط الأدوات الأفقي الخاص بشاشة ال( اعأهM‏ أuل۷0ها)‏ حيث 

توجد الأربع الأيقونات التالية : 


1. مقطچ الرأس Header‏ : 
تظهر اول صفحة فقط وتتكون من جسم وهامش » 


2. المقطع الرئيسي yله8‏ : 

تظهر صفحات التقرير وتتكون من جسم وهامش » حيٿ يتكون 
مقطع الجسم من مجموعات كمصدهإ6 كل مجموعة لها بيانات غير : 
تکراریة ۳€ ھ۴۲ کالعناوین وبیانات تكرlريöة  e Repeating Frame‏ 
كالحقول هذه المجموعات عددها مرتبط بنوع التقرير فمتلاً 

(الجدولي يمتلك مجموعة واحدة فقط مساهإ6 ) في الدرس القادم بإذن الله سنتحدث عن هذه النقطة 
الهامة بشكل تفصيلي أكثر . 


3. مقطع المؤخرة ۴o0٥‏ : 


4. تحرير الامش Margin‏ : 
تظهر هوامش التقرير . 


ملاحظات هامة : 


٠‏ إذا أردت إظهار العناوين على كل صفحة في التقرير (رقم الطالب - إسم الطالب - ... إلخ) 
فيجب إعطاء القيمة كموه۴ ااA‏ للخاصية 0٣١‏ ط٥31‏ خصآمP‏ وذلك في خصائص البيانات الغير متكررة . 


: ط0[ خمذإ۴ القيم التالية‎ 0١ تمتلك الخاصة‎ ٠ 

A Pages .1‏ : يسمح بالظهور في جميع الصفحات » 

A1 But First Page .2‏ : يسمح بالظهور في جميع الصفحات عدا الصفحة الأولى > 
A1 But Last Page .3‏ : يسمح بالظهور في جميع الصفحات عدا الصفحة الأخيرة › 
4. tاDefau‏ : يأخذ القيمة المحددة في محرر التسجيل ۲۷أكأومR‏ › 

۴st Page .5‏ : يسمح بالظهور في الصفحة الأولى فقط » 

e .6‏ وه Last‏ : يسمح بالظهور في الصفحة الأخيرة فقط . 


نحدد (نموذج النس ق ET‏ في شاشة OB TT‏ ومنه مقطع الرس ومنه الخسد لد 
نضغط علی ۴2 لیظھر النموذج الخاص بالجسم ۴٥۲٣۳‏ فنقوم بإاختیار العنصر 1۴۳٣‏ ۷ھامیا٥‏ من شريط 
الأدوات ولنكتب (جامعة العلوم والتكنولوجيا فرع تعز) ونغير ما يلزم من إعدادات متثل نوع الخط وحجمه ولون 
الأمامية ولون الخلفية.. إلخ » ولاحظ بعدها 0 الصفحة عنديداية تنفيذالتقرير لأنها في جزء الجسم 


. j utr] N 
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ل اعا N1 . MODULE Repo CA La MO‏ / بائي اتتفارپر اندوز 14 6 
اهاد نيمات نافذة أدرات برتامم بلقم سيغة اغانة رض تحرير م لع 
A ADAT FA XB 9 Ol Zek PIFÎ | ?‏ 

[ri IPF JBIuU KEN oot, iG FI 


۴ ۴ 3 0 
lull detlelllulutululutulltoludlulllulllluluulsuluil 
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کل م پوعة و 


: 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


اأحاضرة الخاشرة 


2 


° المجاميع ٤ GrOUps‏ 
قبل الخوض بمفاهيم المجاميع يجب أن نعرف ماذا تعني الإطارات في التقاريروهي كالتالي : 


1. الإطار الغير تكراري ع٣‏ ها۴ : . 
خت ونه الات الف کا اکان وال كم جاب ااا ف وا اء كم ته التقرير 


ويرمز له برمز الإطار المنقط »> 


; Renesas me الإطار كار‎ .2 


ويرمز له برمز الإطار المنقط المحتوي على سهم وذلك للدلالة على التكرار » (عدد التكرار يكون بعدد 


. السجلات)‎ 
: کے متال مسط‎ 
۱ 14 Efi IAF الروت‎ ٤ ۱ جال مهیوپ‎ > e 
۱ %1 NTH VAT پیر باشا‎ ٤ ۱ عبدئرحمن عبدالولي‎ ۲ 
۱ 1۲ 1f JAY عبدالعزیز شقف ۱ 1 القصر‎ ۲ 
۱ 0 ‘Ar هریش‎ H ۱ أحمد منصور‎ ٤ 
a ١ ۷۹ ٠١:٣٣۸۲  ةبرضلا‎ ١ ١  فيطللادبص بسام‎ ٠ 
H ۱ A. efe A4 پاپ موسی‎ ٤ ۱ نور إسماعيل‎ 1 
TM SON. 1 
سوا‎ ۱ “0 MeN جواهر جمال ۲ ۱ الروضة‎ ۸ 
۱ Ar “VINA المرور‎ ٤ ۱ عرفات ې‎ ۹ 
۱ A. ۲٣/۰٤/۸۲ وادې لقاشې‎ U ۱ عاد طاهر‎ ۱ 
۲ A We AT محمدلې ۲ ۱ الآجيئات‎ ۱ 
۲ 3 f Ar الشاب‎ ۲ ٣ کسام سیف‎ ۲ 


إذن صفحات التقرير تتكون من رأس وجسم ومؤخرة ولكل منها جسم وهامش » وفي جسم التقرير يتكون 
مقطع الجسم من مجموعات كمرساهإ6 كل مجموعة لها بيانات غير تكرارية ٥٠۳ه۴۲‏ كالعناوين وبيانات تكرارية 
Repeating Frame‏ كالحقول » ويجب أن نفهم القاعدة التالية أثناء تصميم تقرير ما : 
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حاضرات فی اوراکل دىفلویر آ6 ORACLE‏ 


لننشئ تقرير يوضح العلاقة ١٠اهامR‏ بين المادة والطلاب الدارسين لها بحيث نجلب الحقول (رقم المادة - 
إسم المادة - رقم القسم - إسم القسم) من جدول > #زطنك والحقول (رقم الطالب - إسم الطالب) من 
جدول لا » وبواسطة معالج التقارير نجعل نوع التقرير (تجميع لليسار) ولتكن جملة الإستعلام كالتالي : 


Select Sub_No , Sub _ Name , Sub _ Sec , Sub_ Lvl , Stu _No , Stu_Name From 
Subject , Stu Where Sub Sec = Stu _ Sec And Sub _ Lvl = Stu Lvl ; 


ولنلاحظ بعدها ظهور شاشة جديدة تطالب بتحديد المجموعات التي نريد إظهار البيانات فيها وذلك بسبب 
إختيارنا لنوع تقرير غير النوع الجدولي والذي يتكون من مجموعة واحدة فقط » أما حالياً ويإختيارنا لنوع 
التجميع لليسار فسنقوم بنقل الحقول (رقم المادة - إسم المادة - رقم القسم - إسم القسم) كمجموعة 
أولى أما بقية الحقول فستندرج مباشرة تحت مظلة المجموعة الأخيرة وهي هنا الثانية » ثم نكمل بقية 
متطلبات معالج التقرير ولنشاهد بعدها طريقة عرض هذا التقرير . 


× ATE 
تات تا ارت تنص باق مدا اانا رم تر اد‎ 
E SE 2 2 2MA Ol ADSI OI Qul k4 از‎ 
i SRDS e ESS an Te f Isr u 


Avaloble Field Group Fields: 
2 ج ح‎ 

Al STU_NAME SUB_NO 

Al SUB_Naue 
sUB_SEC 
BI SUB ML 
El 

2 الله 2 ا 


تة السابق > تصيمات__|_ إلفاء 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


وللتأكد من عدد المجموعات التي تكونت نحدد ( نموذح البيانات ) الموجود في شاشة ال( أاععزط0 


- ومنه مجموعات ولنشاهد أن المجموعات التي تكونت لدينا حالياً‎ )Navigator 
=1 ® f G_SUB_NO قت ن‎ 
@ SUB_LVL ڪڪ‎ 
`“ SUB_NAME قم المادة - | المادة - رقم الة | الة‎ ( : | û | 
@ SUB NO » لمجموعة الاولى : (رقم المادة - إسم المادة - رقم القسم - إسم القسم)‎ 
“Ê SUB_SEC 
Û 9 Ê G_STU_NO . المجموعة التانية : (رقم الطالب - إسم الطالب)‎ 
E STU_NAME 
€ STU_NO 


ولكننا نلاحظ أبضاً أن : 


المجموعة الأولى ۸N0١_۷8ا6_S‏ هي أب للمجموعة الثانية 6_S۲۷0_۸0‏ . وبالتالي يجب علينا تحديد 
المصدر الرئيسي (المجموعة المباشرة) لكل إطار تكراري من خلال الخاصية 601۷١۴١١‏ وذلك لتوضع حقول 
البيانات عليه لأن ذلك مفيد جد خاصة عند عمليات إضافة حقول جديدة على التقرير يدوي yااقuaمةN‏ . لأن 
الإطار التكراري بالنسبة لحقول البيانات المتوضعة عليه بمثابة القماشية كه۸۷ه€ فلا يمكن أن ينفذ التقرير 
عندما تتوضع الحقول خارجه . 


الإضافةبإستخدام حقلصيغة aاuص۲ه۴‏ : 


إذا أردنا في التقرير السابق أن نظهر إسم المستوى بجوار رقم المستوى سنلاحظ أنه غير متوفر في جدول 
ctهزطSub‏ ولا في جدول ۷ا8 وأنه موجود في جدول آخر لم نقم بجلبه وهو جدول ااا لذلك سنضیف اسم 
المستوی بإاستخدام حقل صيغة aا‏ ا٣۲٥۴‏ وكالتالي : 


علد 


اھا تمت تانذة اموت برنامج عرض تمرير تف ل 
ABHSBEEAQ RD NI 42 2 ُ‏ 
أولآً) نقوم بتحديد ( نموذج البيانات ) ٠‏ 2 
الموجود في شlشة (Object Navigator )J|‏ ت E‏ 


ونضغط ۴2 لتظهر نافذة فيها الإستعلامات 
الموجودة للتقرير (حالياً )Q_1‏ ومن شريط 
الأدوات العمودي نضيف عمود صيغة إلى 
داخل المجموعة الأولى 6_S۷08_١N0‏ ولنرى 
آنه قد تکون شریط تمریر عند إضافته فنقوم 
بتوسعة عرض عناصر المجموعة (نلاحظ أن 
إسم عمود الصيغة الإفتراضي هو ۴_1©) › . a ESSERE‏ 


تانعآً) نقوم بتحديد عنصر عمود الصيغة °۴_1 
ونضغط ۴4 لنعدل خصائصه کالتالی : 


Nit xane Succes hy Comrcded 


حاضرات فی اوراکل دىفلویر أ6 


ORACLE 


ليكن نوع البيانات ع٠م۲۷‏ هاة0 من النوع المحرفي C۸3۲‏ ولنكتب في خاصية aاu"٣۲٥۴‏ ا5Q/‏ ۴1 التالي : 


ثالثاً) ننشئ من شريط الأدوات العمودي 
التابع J_(نموذج (Layout Model _will‏ 
ما بلي : 


: عنصر حقل 4اعا۴‎ ٠۰ 

لنعرض البیانات داخله ثم نجعله في الإطار 
التکراري الاب ۷108_۸0؟_6 بعد فتح قفل 
طور الإحتواء من شريط الأدوات الأفقي 
للسماح بإضافة الحقل » ولا ننسى ريطه مع 


عمود صيغة من خلال الخاصية Source‏ 
وذلك بعد تحدیده وضغط ۴4 » 
Property Value‏ 
Source CF_1‏ 


۰ عنصر نص ۷ھامءا0 : 


FUNCTION CF_1FORMULA RETURN CHAR IS 
X Varchar2 (50); 
BEGIN 
Select Lv1_Name Into X From Lvl 
Where Lvl_No = :Sub_Lvl ; 
Return X ; 


END; 


[r BZU EEN O/et.%. oan i 
7 7 


8 |1 اا 


OIA 7l 


1 ION 0 


E 


4 E 


E 
ا‎ 
أ‎ 


ليوضح عنوان عمود الصيغة وليكن (إسم المستوى) . 
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ك 
محاضرات ف اوراکل دفلور آ6 ORACLE‏ 
e‏ الإضافةبإستخدام (الإاستعلام (SQL Query‏ : 
إذا أردنا في التقرير السابق أن نظهر إسم القسم بجوار رقم القسم سنلاحظ أنه غير متوفر في جدول 
ctهزbطSu‏ ولا في جدول ا6 وأنه موجود في جدول آخر لم نقم بجلبه وهو جدول 68٤10٥۸‏ لذلك سنضیف 
إسم القسم باستخدام الإستعلام yاu۴اQ‏ اSQ‏ وكالتالي : 


أول) نقوم بتحديد (نموذج البيانات) الموجود في شاشة ال( 0۲اةو۷iةN‏ اzعزط0)‏ ونضغط ۴2 لتظهر نافذة 
فيها الإستعلامات الموجودة للتقرير (حاليً 1_@) ومن شريط الأدوات العمودي نضيف إستعلام 501 لينشئ 
إستعلام جديد هو )Q_2(‏ ولتظهر قبل ذلك شاشة والتي يمكنك من خلالها تحرير جملة الإستعلام مباشرة 
في ځStatemen SQL Query‏ أو بناءها من جدید من خلال برنامج باني الإستعلام Bui SQا QU...‏ أو 
إستيرادها من ملف [port SQا Query...‏ وهناك أيضاً زر الإتصال إن لم تكن متصلاً بالقاعدö Connect...‏ 
فنکتب : 


Select * From Section ; 


ثانعآ) ننشئ من شريط الأدوات العمودي التابع ل(نموذح النسق اعأM0‏ uا0لها)‏ ما بلي : 


: عنصر حقل 4اعا۴‎ ٠ 
لنعرض البيانات داخله تم نجعله في إطاره التكراري ولكن أين هو إطاره التكراري فلدينا الآن ثلاث محموعات‎ 
وهي ۽‎ 

المجموعة الأولى 6_S۷8_١N0‏ هي أب للمجموعة الثانية ۸0 6_S۲۷_‏ (من 0_1) › 


والمجموعة التالتة ۸0 6_S٤۴٤٣_‏ (من )@Q_2‏ » وبحسب القاعدة التي تقول أن : 
AAAI‏ 


عدد المجموعات = عدد الإطارات التكرارية 


5 UNNI AN AAAS 
فيجب علينا من أن ننشئ قبل كل شيء ما يسمى ب(الإطار التكراري ۴۲۵۳۴ و١ 2مم ه۸) وذلك من‎ 
ثم نوضع عنصر حقل ۴۵ا۴ داخله‎ . )اھy‎ out Modعا|ا شريط الأدوات العمودي التابع ل( نموذج النسق‎ 

ولينتمي إليه » ولا ننسى ربطه مع إسم القسم من خلال الخاصية ٣٤٥‏ uهS‏ وذلك بعد تحدیده وضغط ۴4 » 

Property Value 


Source SEC_NAME 


۰ عنصر نص ۷ھامءاد : 
ليوضح عنوان عمود الصيغة وليكن (إسم القسم) . 


ثالناً) نقوم بتحديد (نموذجح البيانات) الموجود في شاشة ال(0۲اةوااة. اععزا0) ونضغط ۴2 لتظهر نافذة 
فيها الإستعلامات الووودة ا (Q- 1 & Q_‏ ومن شريط الأدوات العمودي نضيف ربط البيانات 
Data Link‏ بين فو اة 5 ية لإست قم القسم من ا 
ذلك من اجل 
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حاضرات فی اوراکل دفلویر أ6 ORACLE‏ 


ولاحظ في نموذج البيانات آنه قد أضيف مجموعة إستعلام جديدة في جزء (الإستعلامات) ومجموعة جديدة 
في جزء (المجموعات) ورابط بيانات جديد في جزء (روابط البيانات) . 


ك ملاحظة هامة : 


٠‏ تفضل الإضافة بإستخدام حقل صيفغة فاu٣۲ه۴‏ لأنها أسرع بالتنفيذ وأسهل من أجل أنها لم 
تتطلب إنشاء : 

1. إستعلام 1ا5۵ » 

« Repeating Fra ıe يرlركکت إطار‎ .2 

„ Data Link ٽlilaıJl ربط‎ .3 


داعا آ×اعاے 
لداعل ز× اعا 
dN BHSEIEQ ¥3 XOB O Y6 2k | Id al ?‏ 
Fae‏ 
- 
5 
2 
R&S‏ 
2 ۳ 
37 
30 
AE‏ 
ا 
mm‏ 
۰ أ 1 
اسب بسنطین اتکوین إظار متگرر »+ Qa A ss A‏ 


# حقول التسجميع ۷اaصصSu‏ : 

في كتير من الأحيان نحتاج إلى إضافة توابع تجميعية للتقرير (المجموع - المتوسط - الحد أدنى - الحد 
أقصى - العدد - أول - أخير - من الإحمالي % - الإنحراف المعياري - التفاوت) وذلك بغرض عمل 
تلخيص توضيحي لبيانات السجلات خاصة عندما يكون حجم البيانات في التقرير كبير جدآً » وكمثال على ذلك 
لو أردنا في التقرير السابق أن نظمر عدد المواد التي تم تدريسها فستكون الخطوات كما يلي : 


أول) نقوم بتحديد (نموذج البيانات) الموجود في شاشة ال( 0۲†ةو¡N3۷‏ اcعزط0)‏ ونضغط ۴2 لتظهر نافذة 
فيها الإستعلامات الموجودة للتقرير (حالياً 2_@ & )@Q_1‏ ومن شريط الأدوات العمودي نضيف عمود ملخص 
إلى داخل المجموعة الأولى 6_S108_١N0‏ ولنرى أنه قد تكون شريط تمرير عند إضافته فنقوم بتوسعة عرض 
عناصر المجموعة (نلاحظ أن إسم عمود ملخص الإفتراضي هو )C8S_1‏ › 


LT 


حاضرات فی اوراکل دىفلویر أ6 


ثانعاآ) نقوم بتحدید عنصر عمود ملخص C5_1‏ ونضغط ۴4 لنعدل خصائصه 
Property Value‏ 
العدد Function‏ 
aT‏ ي 


Page 


ORACLE 


كالتالي : 


ليكن التابع التجميعي هو العدد C016١‏ وليكن مصدره رقم المادة ١١_طنا؟‏ ولنجعل إعادة تعيين عمود 
ملخص هذا في كل صفحة عو۴a٥‏ ولیس کل تقریر R0‏ (أي في كل صفحة يتم التجميع للعداد تم 
في بداية الصفحة الجديدة يتم تصغير العداد وليبدأً العداد بعملية التجميع من حديد كل صغفحة 


على حده) › 


ثالفا) ننشئ من شريط الأدوات العمودي التابع ل(نموذج النسق اعلأهM‏ خuه¥ها)‏ ما بلي : 


: عنصر حقل 4اعا۴‎ ٠۰ 


لنعرض البيانات داخله ثم نجعله في الإطار التكراري الأب 6_S۷08_١۸0‏ بعد فتح قفل طور الإحتواء من شريط 
الأدوات الأفقي للسماح بإضافة الحقل » ولا ننسى ربطه مع عمود ملخص من خلال الخاصية 50۷۲٤۵‏ وذلك 


بعد تحدیده وضغط ۴4 » 
Property Value‏ 


Source CS_1 


۰ عنصر نص ۷ھامءا0 : 
ليوضح عنوان عمود الصيغة وليكن (عدد المواد) . 


گك سند : 


من الممكن أيضاً إضافة عنصر يوضح عدد الطلاب الدارسين لكل مادة وينفس 


بنفس الطريقة . 
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امحاضرة الهادية مشر 


2 


القوائم Menus‏ : 
وهي القوائم المنسدلة في بداية تشغيل البرنامج ومن المعلوم أن القوائم في ءا٤02‏ تأخذ ملفا مستقلاً 
بحيث نستطيع إستدعاء ملفها التنفيذي من أي برنامج وقد ذكرنا سابقاً أنه عند عمليتي : 


۰ حفظ القوائم 53۷٥‏ يتولد ملف مصدري 501۲٥٤‏ ذو إمتداد ٧8‏ 5.* ويشغله برنامج rۃ€Build Form‏ 
٠‏ الترجمة عاام"۳ه) يتولد ملف تنفيذي عأاءه×ع ذو إمتداد ×%×«5.* ويشغلa‏ ڊرliمج Forms Runtime‏ « 
ليس ذلك فحسب بل يجب أن تكون النسخة التنغفيذية منتمية إلى۴ا1 M050۷‏ معين لإتمام عملية 


نقوم بتحديد ال(كئu١عM)‏ الموجود في شاشة ال(0۲اaوNavi‏ اcعز0b)‏ تم عatعا)‏ لينشئ لنا إسماً إفتراضياً 
للقائمة المنشئة فنحددها ثم ننقر نقرآً مزدوجاً لتصميم القائمة 
E1: Menus 1‏ 
وكالتالي : 3Î MAIN_MENU‏ 
Attached Libraries‏ 
E1: Menus‏ 
S| MENUT‏ 
Items‏ :1= 
برام آ8 
التغارير عا 
&1--Î tell_MENU‏ 
Items‏ :1= 
برنامج_العلافة عة 
برنامخ_الفائمة_المركبة أ 
ہرنامج_القماشية ا 
Ej SEPARATOR_ITEM‏ 
روج آعء 
N‏ ME_النششاریر‏ -51 
Items‏ 1= 
تاثریر_الطلاب ا 
ا 1 ثاثربر_ال سام أا 
ا ي Object Groups‏ 
Parameters‏ :1 
Program Units‏ :1 
Property Classes‏ 
L1: Yisual Attributes‏ 
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حاضرات نی اوراکل دىفلویر أ6 ORACLE‏ 


لنكتب في محرر القوائم عنوان القائمة الأولى (البرامج) ثم ننشئ العناصر التابعة لهذه القائمة من خلال 
إختيار الأمر 00W ١‏ عاجعاإC‏ من القائمة اع« الموجودة في نافذة محرر القوائم أو من خلال الأيقونة 
الموجودة في شريط الأدوات الأفقي في نافذة محرر القوائم ونكتب ( برنامج العلاقة ) وبنفس الطريقة 
ننشئ العنصر الثاني ونكتب (برنامج القائمة المركبة) فالعنصر الثالث بكتابة (برنامج القماشية) فالعنصر 
الأخير (خروج) . نقوم الآن بالرجوع إلى العنصر الرئيس للقائمة الأولى (البرامج) لنحددها ثم ننشئ القائمة 
المجاورة لهذه القائمة من خلال إختيار الأمر R9‏ مtخeaإC‏ من القائمة «6١u‏ الموجودة في نافذة محرر 
القوائم أو من خلال الأيقونة الموجودة في شريط الأدوات الأفقي في نافذة محرر القوائم ونكتب (لتقارير) ثم 
ننشئ العناصر التابعة لهذه القائمة من خلال إختيار الأمر 00W‏ عatعإC‏ من القائمة «eu‏ الموجودة في 
نافذة محرر القوائم أو من خلال الزر الموجود في شريط الأدوات الأفقي في نافذة محرر القوائم ونكتب (تقرير 
الطلاب) وبنفس الطريقة ننشئ العنصر الثاني ونكتب ( تقرير الأقسام) » وبذلك نكون قد إنتهينا فقط من 
مرحلة تصميم القائمة لنلاحظ في ال (كئuا٣۷6)‏ تكون قائمتي البرامج والتقارير بالإضافة إلى قائمة حاوية 


حتى الآن لا يمكن أن نولد الملف التنفيذي لعدم إحتواء الفائمة على أية شغرة مصدرياةله٤‏ 


*٭ خحصائص عناصر القانمة Menu Items‏ : 


Property Value 


5 
6 Visible in Horizontal Menu Toolbar No | 
7 


Icon Filename 


: خمسة قيم كل قيمة لها وظيفة معينة وكالتالي‎ Menu 1e۳ تمتلك خاصية م۲۷‎ ٠ 
› فقط)‎ C008 ه. ”ها۴ : وهي الخاصية الإفتراضية (تنفيذ شفرة مصدرية‎ 
تظهر الإشارة ( > ) لتعبر عن الإختيار المتعدد وذلك بجانب تنفيذ الشفرة المصدرية‎ : hec) ا.‎ 


« Code 
لتعبر عن الإختيار المفرد وذلك بجانب تنفيذ الشفرة المصدرية‎ ) ٠ ( تظهر الإشارة‎ : Radio ع.‎ 
« Code 


2 


› °08 يولد خط فاصل فقط ويدون كتابة أي شفرة مصدرية‎ : Sepa 
ولتقوم بتنفيذ اإستدعاءات معرفة في اللغة‎ M39٤ 1۴٣١ وتاتي مرتبطة مع الخاصية‎ : Magic ه.‎ 


)Cut , Copy , Past 7 WIC i‏ وھي 
1 91 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


ه بالعودة للقائمة الآولى (البرامج) نضيف في محر القوائم عنصر فاصل 5٤۴۸۸۸۲0۸ _1۲۴M‏ قبل العنصر 
الأخير (خروج) بحيث نجعل هذا العنصر يمتلك القيمة١0هإهمه6‏ التابعة للخاصية Menu Item Typ*e‏ 


هه من أهم الخصائص خاصية Menu [tem €0de‏ وهي بمثابة الاعو وا۲۲ الذي سيكتب من خلاله الشفرة 
المصدرية ٥0٥٩٤‏ و بدونها لا يمکن ان يتولد اي ملف تنفيذي للقوائم » قم حالياً بكتابة التعليمة 
Execute _ Query;‏ كشفرة لكل عناصر القائمة لأننا لم ندرس حتى الآن فقرة الربط مع النماذج الأخرى 
Forms‏ „ 


٠‏ عند إعطاء القيمة ١.٠٥‏ للخاصية "u‏ عM‏ ما هاطbاVis‏ فإن العنصر المحدد من القائمة لا يظهر وهذه الطريقة 
مفيدة في منح الصلاحيات لمستخدمين معينين . 


ه٠‏ في كثير من الأحيان نحتاج إلى إظهار الأيقونات على شريط الأدوات الأفقي أو العمودي لتسريع عمل 
البرنامج ولتوقع الإستخدام بكثرة (أشرطة الأدوات التابعة للقائمة وليس لل كهCa"۷€)‏ 
Visible in Horizontal Menu Toolbar ةص»صlëخJl .a‏ 
Visible in Vertical Menu Toolbar ةuıص»صlëخlJl .b‏ 
عند إعطائهما القيمة ۲٠١‏ يعملان على إظهار الأيقونة بالطبع بعد إعطاء القيمة ICON İn ٹöةيصاخلل Yes‏ 
Menu‏ .„ 


ه٠‏ بالإمكان تصميم أيقونة خاصة بالعنصر الذي يتبع القائمة من خلال الخاصية ٠م۳ه٣هاأ۴ 10١‏ وذلك بعد 
إعطاء القيمة ذ۷6 لlنلخlنصıيةö Icon in Menu‏ ,„ 


۰ عند تصمیم برنامج e۲لااuا8 ۴٠۲۳‏ وأردنا إعطاءه القائمة المنشئة فيكون ذلك من خلال منح الملف 
التنفيذي للقائمة كقيمة للخاصية eاu Menu Mod‏ التابعة لل MODULE‏ وکالتالي : 

Property Value 

Menu Module C:\MAIN_MENU.MMX 


٤اعaأع والذي يعمل على تحويل المنشئ بزر ال‎ Switch Orie n†2 لاحظ في محرر القوائم زر 0۸خ‎ ٠ 
„. Create Down yJlJ| Create Right J| jı وكذلك تحويل المنشئ‎ Create Right إلى‎ Down 


٠‏ إذا قمت بتعديل ما على القائمة فيجب أن تحفظ ذلكه۷ةS‏ < هاأ۴ وتترجحمه من أجل أن يتولد الملف 
التنفيذي Jllجııı File > Administration > Compile File‏ . 


. نلاحظ عند التنفيذ وجود قائمة تسمى (نافذة سهل"W1 ) وهي تأتي إفتراضياً مع القوائم المنشق‎ ٠ 


» €10sم_۴٥۲۳۸)''(‎ ; يمكن التحكم بإغلاق النموذج من الذاكرة من خلال تعليمة‎ ٠ 
. إسم البرنامج مباشرة بدون ذكر المسار لأنه موجود بالذاكرة‎ ۲918١ حيث نكتب في المعامل المرسل‎ 


„ q lahawiOnotmailcy) 


Fea 6U 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


آ× الہ ul‏ 
إ إا برح رر نخذة 3 


# القوائم 


المنبتقةبزرالفأارة الأييمن Popup Menus‏ : 
وهي القوائم التي تنبثق عندما نقوم بالنقر على زر الفأرة الأيمن وذلك على الكائن الذي صممت القائمة 
المنبثقة له وتختلف إختلافاً جوهرياً عن القوائم ئu"‏ 6× في أنها : 


ه. لا تحتاج إلى ملف مستقل لإنشائها وبالتالي تصمم داخل برنامج Form Builder J|‏ › 

.b‏ التصميم فيها معکوس فالزر JY Create Down‏ يولد عنصراً مرؤوسا وإنما يولد عنصراً زمیلاً والزر 
Create Right‏ لا يولد عنصرآً زميلاً وإنما يولد عنصرآً مرؤوسا » والسبب في ذلك بعود إلى طبيعة 
عمل وشكل القوائم المنبثقة فهي جانبية وليست عمودية . 

€. تنفذ القائمة المنبثقة من خلال برنlمج Form Builder J|‏ . 


نقوم بتحدید ال(sئuں"عM‏ مupمد۴)‏ الموجود في شاشة ال(a0وNavİi‏ ectز0b)‏ تم Create‏ لینشی لنا إسماً 
إفتراضياً للقائمة المنشئة فنحددها ثم ننقر نقرآً مزدوجاً لتصميم 
اال د 2 : E1: Popup Menus‏ 
القائمة وكالتالي : SSS] SECONDARY_MENU‏ 
Items‏ -1- 
ل البرامج آ٤‏ 
التافارير أا 
= UاMEN_البرامچ ٤‏ -1- 
س Items‏ -= 
ج ا a‏ برنامج_العلافة عة 
ع برنامج_الغائمة_المركبة آة 
برنامج_الشماشية آم 
MENU_التشاریر‏ 5-8 
Items‏ -1- 
نغریر_الطلاب اء 
تالرير_الفسام أا 


لنکتب في محرر ر القوائم عنوان القائمة الأولى 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


فالعنصر الأخير (خروج) . نقوم الآن بالرحوع إلى العنصر الرئيس للقائمة الأولى (البرامج) لنحددها ثم ننشئ 
القائمة المجاورة لهذه القائمة من خلال إختيار الأمر 00W‏ مatعإC‏ من القائمة «٣u‏ الموجودة في نافذة 
محرر القوائم أو من خلال الأيقونة الموجودة في شريط الأدوات الأفقي في نافذة محرر القوائم ونكتب 
(التقارير) ثم ننشئ العناصر التابعة لهذه القائمة من خلال إختıار‏ لمر Create Right‏ من lلقûlئمةöã Menu‏ 
الموجودة في نافذة محرر القوائم أو من خلال الزر الأيقونة الموجودة في شريط الأدوات الأفقي في نافذة 
محرر القوائم ونكتب (تقرير الطلاب) وبنفس الطريقة ننشئ العنصر الثاني ونكتب قرير الأقسام) ‏ ويذلك 
نكون قد إنتهينا فقط من مرحلة تصميم القائمة لنلاحظ في ال (كM6"u)‏ تكون قائمتي البرامج والتقارير 
بالإضافة إلى قائمة حاوية للقائمتين المنشئتين . 


الآن يمكن أن ننغذ البرنامج مع عدم إحتواء القائمة على أية شغرة مصدريتعله٤‏ 


٭ خصائص عناصر القائمةانلمنبiقة Popup Menu Items‏ : 
نفس الخصائص المشروحة في القوائم ا6 » عدا : 
ه. ظهور القائمة المنبثقة يكون من خلال منحها لخاصية UاM€۸‏ مupمه۴‏ المضمنة في خصائص (العناصر 


tems‏ أو القماشية كج۷" ه٤)‏ فمثلاً لإظهار القائمة الحاوية لقائمتي البرامج والتقارير في عنصر 
tem‏ ayامDis‏ فاننا نجعل خصائصه کالتالی : 


Property Value 
1 Popup Menu _SECONDARY_MENU_ 
2 Database Item No 


ط. لا توجد أيقوناتها على أشرطة الأدوات الأفقية أو العمودية 
أي لا توجد بlq‏ خڂخڏصٍilنص Visible in Horizontal Menu Toolbar‏ ھ, Visible in Vertical Menu‏ 
Toolbar‏ « 


ع. بالطبع لا وجود للملف التنفيذي المستقل أو قائمة تسمى ( نافذة سهلمWİ‏ ) تأتي إفتراضياً أثناء 


والآن إذا أردنا إنشاء عنصرين من النوع 1٠"‏ ayامDis‏ 


Property Value Property Value 


1 Popup Menu جماربلا_MENU‎ 1 | Popup Menu ریراقتلا_MEN‎ 1 
2 Database Item | No 2 | Database Item | No 


„ q lahawiOnotmailcy) 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 
٭ طرق الربط بين أكثر من )۴0۲"١(‏ أو بين ال(١٣۲٣٥۴)‏ رال(†NRepor)‏ : 


عند التحدث عن طرق ربط أكثر من نموذج يتبادر إلى الذهن مباشرة موضوع النموذج الأب ۴4٣6٣٤‏ والنموذج 
الإبن ٥۸11١‏ فالأب يستدعي الإبن و”أااة٥‏ » تحت مظلة ما يدعى بواجهة المستندات المتعددة أأإMD01)Mu‏ 
Interface)‏ 0cumentsط‏ وبالتالي فإن طريقة إظهار نموذج آخر من نموذج حالي تختلف من برنامج إلى آخر 
حسب طبيعة عمل البرنامج وهذه الطرق مهما إختلفت فهي نتيجة للضفط على زر أو قائمة رئيسية أو قائمة 
منبثقة . وطرق الربط كما يلي : 


1. OPEN FORM (Form Name , Active Mode , Session Mode , Data Mode , 
Paramlist_ Name Or Paramlist_ Id) ; 


2. CALL FORM (FormModule Name , Display , Switch Menu , Query Mode , 
Data _ Mode , Paramlist_ Name Or Paramlist_ Id) ; 


3. RUN_PRODUCT (Product , Module , Comm Mode , Exec Mode , Location , 
Paramlist_ Name Or Paramlist_ Id , Display ) ; 


ك ملاحظة هامة : 


۰ لا یمکن الربط بين ال(" )۴٥۲‏ وال(ا0۲معR(‏ إلا عن بطريقة lالرطRun_Product‏ . 


@® طريقةالربط الأرلى (فتح النموذج ۴0۲۳ ١”عم0)‏ © 
وتمتلك ال كئأ٣عص‏ يناه التالية : 


1. اسم lلgaiڏذج Form name‏ : 
حيث نكتب هنا مسار البرنامج الإبن المراد فتحه » 


2. aiط‏ ıiiil|lط Active Mode‏ : 
له قیمتین إما ۷۵ا۸ أي انه بعد فتح النموذج الإبن سينتقل المؤشر مباشرة إلى كتل النموذج الإبن (وهو 
الإفتراضي) أو #خة۷آ†»A‏ _0۸ أي أنه بعد فتح النموذج الإبن سيبقى المؤشر في النموذج الأب › 


3. نمط |llجlلسة Session Mode‏ 1 
لها قيمتين إما ١0أئئه0_S.‏ وتعني أن النموذج الإبن والنموذج الأب ليسوا في جلسة واحدة وبالتالي إذا 
تم عمل تثبيت أو تراجع فإنه سيتم حفظ التغييرات التي حدتثت على النموذج الإبن فقط (وهو الإفتراضي) › 

أو «دiكهك‏ وتعني أن النموذج الإبن والنموذج الأب في جلسة واحدة وبالتالي إذا تم عمل تثبيت أو تراجع 
فإنه سيتم حفظ التفييرات التي حدثت على النموذج الإبن والنموذج الأب معا . 


: Data Mode ٽlنiluıud|l‎ bai .4 

لها قيمتين إما aخaةibrary__0ا N0_Share_‏ وتعني عدم مشاركة البيانات لنموذج الأب والإبن في مكتبة 
بيانات واحدة (وهو الإفتراضي) أو aخة ١4۲۷_2٥‏ طأا_هإهطS‏ وتعني مشاركة البيانات لنموذج الأب والإبن في 
مكتبة بيانات واحدذ 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


Examples : 


Open Form ('"C:\Prog4.Fmx') 7; 


Open FOEM("C:\PEOGA4.TmME' yy ; r ; PL ID); 


@ طريقةالربط الثنانية (إستدعاء النموذج Call Form‏ & 
وتمتلك ال كئأ٣عص‏ يواه التالية : 


1. wlم‏ aillمgذڏذج FormModule name‏ : 
کما شرح سابقاً 


2. العرض ۷ھامءi٥‏ , 
له قيمتين إما ۸14۵ أي أنه يستدعي النموذج الإبن ويخفي النموذج الأب (وهو الإفتراضي) أو مid١٨_N0‏ 
أي أنه يستدعي النموذج الإبن ويجعل النموذج الأب موجودآً خلف النموذج الإبن ولكنه غير محفز (غير منشط) 


3. ilêئمة‏ lلiتJıgz Switch Menu‏ : 
لها قيمتين إما P13٥#‏ ۸0_۸۵ وتعني عدم تبديل قائمة النموذج الأب وإنقلها للنموذج الإبن عند الإستدعاء 
(وهو الإفتراضي) أو ٤#‏ هام00_۸# وتعني تبديل قائمة النموذج الإبن بما لديه من قوائم . 


Query Mode ماڻlعgiwۈlJl‎ bhai .4‏ : 
لها قيمتين إما 0٣1¥‏ _۷مN0_Qu‏ وتعني فتح النموذج الإبن بغرض تطبيق العمليات المختلفة من إضافة 
وتعديل وحذف وإستفسار ... إلخ (وهو الإفتراضي) أو ل" ۲۷_0هQu‏ وتعني فتح النموذج الإبن بغرض 


الإستفسار فقط . 
Data Mode ٽlنiluJl‎ bai .5‏ : 
کما شرحت سابقاً . 
6. إسم المعامل أو رقم اJمعJl۳ Paramlist Name Or Paramlist Id‏ : 
كما شرحت سابقاً . 
Examples :‏ 


Call FOrM (CIN PEOG4:Fms"')? 


Call Form(TC:\PEOG4-Emx" , Hide ;, No Replace ; No QOüery Only)? 


@& طريقةالربط النانلنفنةiûiêöنفiinJlijqج Run Product‏ ®& 
وتمتلك ال كئأ٣عص‏ يواه التالية : 


اسم المنتج Product‏ 


WON TES‏ 1 [ 1 أو 2 أو 3 ] وينفس 
N‏ | 0 96 
ڪِ 


حاضرات نی اوراکل دىفلویر أ6 ORACLE‏ 


حيث نكتب هنا مسار البرنامج الإبن المراد فتحه »> 


3. نمط الاتنصJl Comm Mode‏ : 
لها قيمتين إما ئuامصمااإcعمSy‏ وتعني السماحية بالعمل على النموذج الأب بجوار العمل مع النموذج الإبن 


أو Asynchronous‏ وتعني العمل مع النموذج الإبن فقط . 


: Exec Mode ذıغiil|l نمط‎ .4 
Batch ڦ‎ ( Form Builder & Report Builder & Graphics Builder ge فا ا م‎ ( Runtime lo| jıتمıق له‎ 


. فقط‎ ) Builder & Graphics Builder (وتستخدم مع‎ 


5. الموقع ٣‏ ەLocati‏ : 
له قیمتین إما ان یکون ملف نظام ۸٥ء5۷‏ ۴1۵ او ملف مخزن على قاعدة البيانات مsءةbھاaض٥‏ . 


: Paramlist Name Or Paramlist Id 


7. العرض ۷ھامءا : 
تستخدم مع الرسم البياني وذلك لإختيار نوع المخطط كء‌iمGra‏ . 


Examples : 


Rûn Product (l1 , "CI\PEOG4.Fmx" , Synchronous , Runtime , Filesystem , 


E yy TT) 


Run Product{(2 , 'Ci:\Rep4.Rep'")? 


ك ملاحظة هامة : 
كنا قد أشرنا في فقرة القوائم إلى فقرة الربط مع النماذج الأخرىء٣۲۳٠۴‏ وأجلنا آنذاك كتابة الشفرة المصدرية 


مله لعناصر القائمة وها نحن الآن بعد إتمام هذه الفقرة نعاود كتابة الشفرة لتلك العناصر بعد تحديد العنصر 
وضغط ۴4 ومنها خاصية Menu ite" Code‏ ولنکتب کما هو موضح ما يلي : 


قائمة البرامج 
(برنامج العلاقة) 


Open Form ("Ci\Progl1.Fmx')7 


(برنامج القائمة المركبة) 
Call Form TCi\Prog2.Fmx'" , Hide , No Replace , Query Only)?‏ 


(برنامج القماشية) 
Call Form" Ci\Prog3.Fmx" , Hide , Do Replace , No Query Only);‏ 


قائمة التقارير 


1 q1yahawiChotmail 0 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


(تقارير الأقسام 
Run Product{l2 , TC:\Rep2.Rep" , SyncehronGus , Runtime , Filesystem , ""‏ 


و 


: Parameters ٽتںږمnliaرagnلا‎ % 


أحياناً وقبل فتح النموذج الإبن نريد أن نرسل له وسائط معينة (متحولات) لكي نتحكم بطريقة عرضه فمثلاً قد 
نحتاج لذلك في برامج : (الطلاب ودرحاتهم » الدوائر وموظفيها » ... إلخ) أشبه ببرامج ال Relations‏ « 
ولعمل ذلك لا بد لنا أولاً من معرفة الخطوات التالية : 


1. قي النموذج الأب : 
Parameter J| dAjgi V7‏ « 
> نرسل القيمة . 
2. في النموذج الإين : 
> ننشئ ۲عاعمص هام۴ متوافق مع ال ٣عأعمصها۴a‏ المرسل » 
> نعمل على إستقبال القيمة التي يحملها ال ۲عأمصما۴a‏ المرسل » 


ا مثال ذلك : 
یوجد لدینا ۴٥۲٣۳‏ يحتوي على بيانات الطلاب 510 و ۴٠١۲۳١‏ آخر يحوي الدرجاتٽت MARK‏ › 


المطلوب : ربط النموذجین ۴٥۲۳٣۶‏ بواسطة jزر Parameters مIدختulڊ Push_Button‏ ؟ 


اداعلے J rae‏ اعلہ 000 
ل 


[× آجاے برح اتقارير ناقا × ها لجراء تحرير استعلام قطمة سمجل حتقل تانذة تطيمات 3 
۹ ا ?ISCRC: b> aa TAS BSaX #3 Q 3 ss.‏ 
Fee‏ 
تہ مہ فصب نرت CE‏ أ 1 
اج a aE E, RET E EA BL E‏ 
اجو اهر جا“ RES. 7 a Jî FT “" [CCT‏ ` ۲ 
| عرنات ى سڪ E [ 3 [ mE kK‏ 
| مسا اهر ۰ 1 ۰ ڪڪ a‏ 
آم لے 1 
1 
Parameter 1‏ 
سج bêti‏ سج 
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1. في النموذج الأب نعرف ال #۲أ#٣۳ه۲ه۴‏ و نعمل على تحميله بالقيمة و إرسالها وذلك بواسطة حدث 
)(WHEN_BUTTON_PRESSED)‏ التابع لزر الدرجات وکالتالي : 


Declare 
PL ID Paramlist; 


تعريف متحول من نوع الان امار 


Begin 


Get_ Parameter List ('Student_ Number'); 


PL ED 
إحضار البارامتر‎ 


إن وجد إلى داخل المتحول 
If Id Null (PL_ID) Then‏ 
فحص المتحول هل البارامتر منشئى أم لا 
PL ID Create Parameter List ('Student_ Number");‏ 


إنشاء بارامتر جديد إن م يكن قد أنشئ من قبل 


Else 
Delete Parameter (PL ID, 'Student_ Number'); 


حذف القيمة التي كان 


البارامتر محملاً إياها 


End If ; 


Add Parameter (PL ID, 'Student Number", Text Parameter, :Stu.Stu_ No); 


تحميل االمخا زر اهترز الخصي :تاالفيهة (رقم الطالب) 


Run Product (1, "C:\Mark\Nodulel.Fmx';, Synchronous, Runtime, Filesystem, PL 1 


D); 
فتح النموذج الإبن مع رسال قيمة‎ 
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2. في النموذج الإبن نقوم بتحديد ال(كإعأعمصماإ۴a(‏ الموجود في شlشة Create »۾i (Object Navigator)J|l‏ 
لينشئ لنا إسماً إفتراضياً للمعاملات فنحدده ثم نضغط ۴4 ونغير قيمة خاصية الإسم البرمجي كما يلي : 

Property Value 

Name Student_Number 

وفي حدٿ تحمJı‏ |gnilذج )WHEN_NEW_FORM_ INSTANCE)‏ نكکتب التالي : 


Set_ Block Property ('MARK', Default Where, 'Mark Stu:=Parameter.Student_ Nu 
mber'); 


إنتقاء سجلات جدول الدرجات عندما يكون رقم الطالب مساوياً للبارامتر 


الذي ت إستقجال القيمة الخرسلة ته 


Execute _ Query; 


إستخدام القيمة بالإستعلام 


ملاحظات هامة : 


٠‏ إذا أردت تحميل القيم (رقم القسم - رقم المستوى - رقم الطالب) فما عليك سوى كتابة تعليمة 
لتحميل تلات مرات ويقيم مختلفة مرة برقم القسم ومرة برقم المستوى ومرة برقم الطالب 
Add Parameter‏ . 

يوجد iوع‏ خر )Pata Parameters) Jl yg (Text Parameters) JI yııغ Parameters J| ja‏ ويیستخدم 
لۈرسJlw‏ مجeanعة‏ wجJ Record Group‏ . 

۰ عند إرسال اParamete‏ من برنامج مصمم بال ۲علاuiا8 ۴۵٥۲۳‏ وترید اإستقباله في برنامج مصمم بال 
Report Builder‏ فإنك ستستخدم ۶٤٥٣ص‏ raا۴a‏ إهsل‏ لإستقبال القيمة . 
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۰ 


اأهاضرة الشانية مشر 


* التعامل مع ملفات الصورة 
يمكن التعامل مع ملفات الصورة بإاحدى طريقتين : 


1. تكون الصور موجودة على ملفات نظام ۴۴ "عاكر؟ وهذه الطريقة لا تعتمد على قاعدة البيانات 
Non_DB‏ « 
2. تكون الصور مخزنة داخل قاعدة البيانات عكةطاهةأة0 وهذه الطريقة تعتمد على قاعدة البيانات 08 . 
(والطريقة التانية هى الأفضل من احل عمليات الإستيراد والتصدير والامنية) 


أو : بواسطة ملفات النظام ۴1۲ S٣‏ _: 


نضيف من شاشة ال ۲ ٤d٥‏ youtةا‏ عنصر صورة ۴۳ع[ م1۳29 ولتكن لديه الخصائص التالية : 


Property Value 

1 Name TEST_IMAGE 

2 Image Format BMP 
ي‎ oT 
2 E. CT TT 
5 | Display Quality) High 
6 | Popup Menu] 
ي یھی ي‎ 
ب ج‎ a TT 
٠ 9) Popup Menu) 
10 | Database Item)_ No 


وعمق الصورة ١امء0‏ عو1"a‏ أصلي 
Display Quali E DY‏ 


حاضرات ن اوراکل دىفلویر أ6 ORACLE‏ 


بحيت إذا كان حجم الصورة كبير يقوم بإضافة شريط تمرير لرؤية الصورة آم نريده موائمة أءلازك۸ بحيث يوائم 
الصورة على حجم الإطار الذي يحتويها . 


بعد ذلك نحدد الحدث المناسب لذ 
(Trigger : WHEN_IMAGE_PRESSED)‏ 
Declare‏ 


FileName Varchar2 (50); 


تعريف متحول من نوع حرفي ليخزن مسار الصورة 


Begin 


FileName $= 'C:\ Img Stu\Amerah. Bmp" 7 


إسناد ملف صورة نقطية إلى المتحول 


Read Image File (FileName, 'Bmp', 'Test_ Image') ; 


قز اءة ملف الضورة وذلك من المتجول بامتداد نقطي إل داخل العنضر الدكدي تعرض 
به الصورة 


FileName := Get File Name ; 


ناتج إستدعاء دالة جلب الملف (معالج الفتح) يخزن إلى المتحول 


FileName := Get File Name('Ci\Img Stu\" , 'Amerah:Bmp" , "Bitmap 
Files (*.Bmp) |*.Bmp|'); 


إستدعاء دالة جلب الملف مع منحها مسار إفتراضي وقيمة إبتدائية ونوع ملفات 
صورة نقطية 


FileName := Get File Name ('C:\Imgğ_Stü\' , 'Amerah. Bmp" , "Bitmap 
Files (*.Bmp) |*.Bmp|', 'Jpg Files (*.Jpg) |*.Jpg|', 'Gif 
EFlleS{(*.GELE) [#:GILEITZTALL Files) IF * IF 
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فكلمة ١٥ا۴‏ مة"۳ا8 هي عبارة توضيحية من إختيار المبرمج › 
وال(م"8.*) هي القيمة التي ستعرض داخل ١۳ا1‏ ءأا الخاص بأنواع الملفات › 


وال(م"8.*|) هي القيمة الإبتدائية للملف » وقس بقية التعليمات على غرارها . 


mm 11< تمتلك ال‎ et ۴l Name التعلىمة‎ 
-_ = _ J-O aةىلاتلا‎ arguments 


« Directory_File ılجzJl‎ مw|إ‎ .6 

7. إسم الملف الإبتدائي ۳۴ e_۸.2اأ۴‏ » 

8. تعليمة فلترة الملفات المعروضة اا۴ » | 
9. رسالة توضيحية Message‏ » [ تہ ) = چ ت 
0. نوع المعالج ھJ‏ ھg E El . SAVE AS ۾Î OPEN‏ > ! 


(Trigger : WHEN_BUTTON_PRESSED) 
Declare 


FileName Varchar2 (50); 


Begin 


FileName += Get File Name 'C:\ Img SÎËüN\' , 'Amerah.Bmp" , "Bitmap 
Files (*.Bmp) |*.Bmp|', Save _ File); 


ناتج إستدعاء دالة جلب الملف يخزن إلى المتحول بعد فتح معالج الحفظ بإسم 


Write _ Image_File (FileName, 'Bmp','Test_ Image') ; 


كتابة ملف الصورة وذلك من المتحول بإمتداد نقطي من داخل العنصر الذي تعرضص 
به الصورة 


End; 


حاضرات فی اوراکل دىفلویر أ6 ORACLE‏ 


FileName i= Get Filé Name("C:\ IMO" [[:5tu See | [tû TWwl | [:8tu No 
|| '.Bmp'); 


(Trigger : WHEN_NEW_RECORD_INSTANCE) 
Declare 


FileName Varchar2 (50); 


Begin 


FileName := Get Filê Name 'Ci\Imgo\' |[|:Stü Sec ||:Stu LvL |[Stu No 
|| '.Bmp') ; 


Read Image_File (FileName, 'Bmp',' Test_Image ') ; 


End ; 


وهذه هي الشفرة المصدرية المعتمدة عند التعامل مع الصور بواسطة ملفات النظامعاآ۴ ٣6ء5‏ . 


ثانياً : بو اسطة قاعدة البيانات مsئba Daa‏ : 


1. ولعمل ذلك لا بد من إضافة هذا الحقل بأمر ا50 وكالتالي : 
SQL> alter Table Stu Add (Stu_Img Long Row);‏ 


2. (إذا قمت بإنشاء الحقل بعد جلب البیانات إلى ال٣۴۵۲۳‏ فقم بتحدید ال (۲U؟)‏ )ها8 ھtھD‏ ثم إنقر 
على زر الفارة الايمن لتختار Data Bloc) Wizard‏ ومنە التبویب عِاطھا تم إضخط jllر Refresh‏ 
وبعدها قم بجلب العنصر 5۲1_156 تم إضغط نهاية) 


3. إمنح الخصائص التي تم ذكرها سابقاً لعنصر الصورة 1M6_ل51۷‏ ولكن لاحظ أنها هنا معتمدة على قاعدة 
البيانات » 
Property Value‏ 


Database Item Yes 


4. نقوم بكتابة الشفرة المصدرية في حدث (الدخول على عنصر جديد) التابع للحقل 57۷_1۷6 وكالتالي : 
(Trigger : WHEN_NEW_ITEM_INATANCE)‏ 


Declare 


mm _ 
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Begin 


FileName := Get File Nameê("CI\ImMON\' ||:Stüû Sec [|| :Stü Iwl || :8tuû No 
|| '.Bmp') ; 


Read Image_File (FileName, 'Bmp',' Stu.Stu_Img') ; 


End § 


التعامل مع ملفات الصوت : 
يمكن التعامل مع ملفات الصوت باحدى طريقتين : 
1. يكون الصوت موجود على ملفات نظامعاأ۴ ٣عأكرS‏ وهذه الطريقة لا تعتمد على قاعدة البيانات ١0١_068‏ 


2. تكون الصوت مخزن داخل قاعدة البيانات 2#طةاة0 وهذه الطريقة تعتمد على قاعدة البيانات 08 . 
(والطريقة التانية هى الأفضل من أحل عمليات الإستيراد والتصدير والامنية) 


أو : بواسطة ملفات النظام ۴1۲ S٤٣‏ _: 


نضيف من شاشة ال ٤d٥‏ youtةا‏ عنصر صوت ۴۳آ ١اه‏ ولتكن لديه الخصائص التالية : 


Property Value 

1 Sound Format WAV 
2) Audio Channels Automatic 
BE 3 Compress Automatic 
Sound Qualty Automatic 

E 5 __ Popup Menu. 

١ 6 /_/_/_ Database Item No. 
َ 7 Show Play Button Yes. 
_ Show Record Button No. 

TT‏ د 

e i 

ET TTT 2 
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| 13 Show Slider Yes 


حيث ننتقي تنسیق الصوت Sound ۴٥۲"2‏ ب WA۷‏ . وقنوات الصوت dio Cha "es‏ بالأتوماتیکیة 
Automatic‏ . بینما نجعل الضغط ۲٥‰5‏ م٥0٥‏ أتوماتيكي ۸٥٣٣1٥‏ وجودة الصوت ۷اااةQu 50u”‏ أتوماتيكية 
Automat‏ . ويفضل أن نظهر على عنصر الصوت أزرار (بداية تشغيل التسجيل والتحكم بحجم الصوت ... إلخ) 
من خلال منح القيمة Show Time . Show Volume Control «. Show Play Butt0¬ ) صئlصخلل es‏ 
(Show Slider « Indicator‏ „ 


(Trigger : WHEN_NEW_RECORD_INSTANCE) 


Declare 


FileName Varchar2 (50); 


Begin 


FileName i= Get File Name( 'CiN\SnON' || :Stüû Sec 
ll'.Wav') ; 


:Stu Lvl || :Stu_ No 


Read Sound File (FileName, 'Wav',' Test_Sound ') 


r 


End ; 


ثانياً : بو اسطة قاعدة البيانات مsئaط Daa‏ : 


ولعمل ذلك لا بد من إضافة هذا الحقل بأمر ا50 وكالتالي : 
SQL> alter Table Stu Add(Stu_Snd Long Row);‏ 


2. (إذا قمت بإنشاء الحقل بعد جلب البیانات إلى ال٣۲٥۴۵‏ فقم بتحديد ال (۲0؟) )ها8 هtه ٥‏ ثم إنقر 
على زر الفأرة الأيمن لتختار Data Block Wizard‏ ومنه التبویب eاطھ۲٢‏ ثم إضخط llلjر Refresh‏ 


وبعدها قم بجلب العنصر 511_520 ثم إضغط نهاية) 


3. إمنح الخصائص التي تم ذكرها سابقاً لعنصر الصوت 51۷_5١0‏ ولكن لاحظ أنها هنا معتمدة على قاعدة 
البيانات » 
rope) >‏ 
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4. نقوم بكتابة الشفرة المصدرية في حدث (الدخول على عنصر جديد) التابع للحقل 57۷_5۸0 وكالتالي : 
(Trigger : WHEN_NEW_ITEM_INATANCE)‏ 


Declare 


FileName Varchar2 (50); 


Begin 


FileName := Get Filê Name( 'C:\SndN' [|| :Stü Sec 


lI :Stu_ Lvl ||:Stu No 
ll '.Wav') ; 


Read Sound File (FileName, 'Wav', ' Stu.Stu_Snd') ; 


ENG 
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$ وامرتحجيم الصورة: TIED‏ ` 
لنقم بتحديد ال(كئu”عM‏ مuمد۴)‏ الموجود في شاشة )Object Navigato (J|‏ تم Ej MENU23‏ 2 
٤ا‏ لننشئ قائمة منبثقة بزر الفأرة الأيمن حيث نكتب في محرر القوائم rE‏ 
عنوان القائمة (تحجيم الصورة) ثم ننشئ العناصر التابعة لهذه القائمة من اظ تحجيم_الصورة ن 
خلال إختيار الأمر tإوRi Create‏ من القائمة u٣عM‏ الموجودة في نافذة محرر Items‏ 3 
القوائم أو من خلال الأيقونة الموجودة في شريط الأدوات الأفقي في نافذة e‏ 

محرر القوائم ونكتب ( تكبير ) وبنفس الطريقة ننشئ العنصر الثاني ونكتب موائھة 7 


(تصغير) فالعنصر الثالث بكتابة (موائمة( « ومن خلال خزlصيö Menu Item‏ 
مهه التابعة لكل عنصر في القائمة نكتب الشفرة المصدرية وكالتالي : 


(تکبیر : ۸7 €†1) 


Image _ Zoom ('Stu_Img' , Zoom In Factor , 3) ; 


تكبير بمقدار ثلاث مرات 


)!٤۴٣ : (تصغیر‎ 


Image_ Zoom ('Stu_Img' , Zoom Out _ Factor , 2) ; 


تصغير بمقدار مرتين 


(Item : (موانمة‎ 
Image_Zoom('Stu_Img' , Adjust_To_Ft) ; 

ولنحدد ظهور هذه القائمة المنبثقة على عنصر صورة الطالب و1۳_نا؟ وكالتالي : 
Property Value‏ 


Popup Menu | _MENUöرgصJل|‎ مıجحت‎ 


ك ملاحظات هامة : 


» 10١9 ۸0۷ لايمكن أن يحتوي الجدول على أكثر من حقل من النوع‎ ٠ 
: الفرق الجوهري بين التعامل (بواسطة ملفات النظام أو بواسطة قاعدة السبانات)هو أن‎ ٠ 
ملفات النظام عند الخروج من البرنامج (إنهاء البرنامج) تطالب المستخدم بالحفظ لتؤثر على قاعدة البيانات‎ 


. Database 
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غالبا ما نقوم بالإستيراد والتصدير من خلال أي زر آو عنصر قائمة منبثقة ولنكتب فيها الشفرة المصدرية 


Expdat. Dmp') ; 
Expdat. Dmp Full = Y') ; 
Expdat.Dmp') ; 
Expdat. Dmp Full = Y') ; 


i 


2 


\ 


شتير اة قا قو ة, تا تات 


\ 


تتضد يز قا عفاة انات 


SRE 


التالية : 
( التصدير) 


Host ('Exp Userld = Ust/Taiz File = C 


المستخدم d!‏ متف دد 


Host ('Exp Userld = Ust/Taiz File = C 
تاخز قا قكة . جتاقات. كاملة إل مكف شدذة‎ 
الإستيراد)‎ ( 

Host ('Imp Userld = Ust/Taiz File = cC: 


المستخدم من ملف محدد 


Host ('Imp Userld = Ust/Taiz File 


سكير آ3 قا عة تا تاق كا هة ,هن مكف دد 


کے تلمح : 


٠‏ التعليمة غ5٥۸‏ تقوم بإاستدعاء أمر نظام التشغیل ٣ا۸‏ 3 ٤٣ها6‏ ثم تستدعي أحد البرنامجين ۲۴×ع٤‏ أو 
(حسب الطلب) ومن ثم تعطي معاملاتها كاملة للبرنامج ولاحظ عند كتابتها إمتلاكها لفاصلتين 


علويتين إحداها بالبداية والأخرى بالنهاية . 


. هناك أيضاً تصدير أو إستيراد لجدول معين من مستخدم محدد من قاعدة البيانات‎ ٠ 
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ملحق‌الصيغ العامة لحملا 5۵ 


((DML & DDL & DCL )) 


select...from...; 
select...from...where...; 
select...from...order bY...; 
select...from...grOoUp bY...; 
select...from...having...group bY...; 
select...from...where...[in or =] select...from...where...; 
insert into...values...; 

insert into...select...; 
update...set...; 
update...set...where...; 

delete from...; 

delete from...where...; 

create...; 


create...as select...; 


<q gljhawinoinailc| 


alter...add... 


alter...modi 
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Hiredate Sal Comm 


Deptno 


jlyahawiOnotmail e0 


Mgr 


Comm 


ORACLE 


alter... 


grant... 


grant... 


revoke...from...; 


revoke...on...from...; 


= Fields of Emp Table 


Empno Ename Job 
= Fields of Dept Table 
Deptno Dname Loc 
= Fields of Bonus Table 
Ename Job Sal 


= Fields of Salgrade Table 


Grade LoSal HiSal 
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- select * from Tables_name ; 
- select Fileds_name from Tables_name ; 


- select Fileds_name from Tables_name where Conditions ; 


- select Fileds_name from Tables_name order by Filed_name Sort type [Asc or Desc] ; 
- select Fileds_name from Tables_name order by Filed_name i Sort type, ..., 


Filed_name n Sort type ; 


- select Fileds_name from Tables_name group by Fileds_name ; 


- select Fileds_name from Tables_name group by Fileds_name having Conditions ; 


- select Fileds_name from Tables_name 

where Conditions [in or =] select Fileds_name from Tables_name where Conditions ; 
- insert into Table_name (Fileds_name) values (Values by Fields Sort [Serial] ) ; 

- insert into Table_name values (Values by Table Description) ; 


- insert into Table_name (Fileds_name) values (& message ,'& message (string), ...); 


- insert into Table_name select Fileds_name from Tables_name where Conditions ; 
- insert into Table_name (Fileds_name) select Fileds_name from Tables_name 
where Condition ; 


- update Table_name se 


- update Ta am 
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- delete from Table_name; 

- delete from Table_name where Conditions ; 

- create user User_name identified by Password ; 
- create role Role_name ; 


- create role Role_name identified by Password ; 


- create table Table_name (Filed_name i Filed_type i constraint Constraint_typPe , ..., 


Filed_name n Filed_type n constraint Constraint_type) ; 


- create table Table_name (Filed_name i Filed_type i constraint Constraint_type references 
Table_name(Filed_name i), ..., 


Filed_name n Filed_type n constraint Constraint_type references Table_name(Filed_name n)) 


, 


- create view View_name as select Fileds_name from Tables_name where Conditions ; 


- create synonym Synonym_name for User_name.Table_name ; 


- create index Index_name on Table_name (Filed_name i, ... ,Filed_name n) ; 


- create unique index Index_name on Table_name (Fileds_name) ; 


a _ 
- alter table le_n MAMÎ noimail 
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- alter table Table_name modify (Filed_name Filed_type) ; 


- alter table Table_name drop (Filed_name Filed_type) ; 


- alter user User_name identified by New Password ; 
- drop user user_name cascade ; 


- drop role role name; 


- drop table table_name ; 
- drop view view_name ; 


- drop synonym synonym_name ; 


- drop index index_name ; 


- drop unique index index_name ; 


- grant Role_name to User_name ; 

- grant Role_name to Role_name ; 

- grant privileges on Table_name to User_name ; 
- grant privileges to Role_name ; 


- revoke Role_name from User_name ; 
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- revoke Role_name fro 
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- revoke privileges on Table_name from User_name; 


- revoke privileges from Role_name ; 


- revoke privileges on Table_name from public ; 


- revoke all on Table_name from public ; 
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